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(57) Abstract 

The invention relates to a bus system for 
DFPs DE 16 88 A 1 and to building blocks with two 
dimensional or multidimensional programmable 
cell structures (of type FPGA, DPGA or the like), 
characterized in that a) the bus system comprises a 
plurality of electrically independent bus segments 
disconnected by nodes, b) the nodes actively 
connect or disconnect bus segments, whereby bl) 
several bus segments are joined and connected by 
gates to a bus bar located inside the node or b2) 
connection occurs directly via circuitry elements, 
drivers and/or registers, c) each node has a routing 
table where information on the structure of the 
connection is stored, d) each node has a monitoring 
unit, which verifies independently if a connection 
can be established or not. 

(57) Zusammenfassung 

Ein Bussystem fur DFPs gemSB DE 44 
16 881 Al, sowic Bausteine mit zwei- oder 
mehrdimensionaJer programmierbarer Zellstruktur (der Gattungen FPGA, DPGA, o.dgl.) ist dadurch gekennzeichnet, daB a) das Bussystem 
aus einer Vielzahl voneinander elektrisch unabhangiger Bussegmente besteht, die tiber Knoten getrennt sind, b) die Knoten Bussegmente 
aktiv zusammenfiigen oder trennen, wobei bl) entweder zum Zusammenfugen mehrere Bussegmente uber Tore auf eine, sich innerhalb 
des Knoten befindende Sammelschienen zusammengeschaltet werden, oder b2) die Zusammenfugung direkt uber Schaltelemente, Treiber 
und/oder Register erfolgt, c) jeder Knoten eine Routingtabelle besitzt, in der die Informationen uber den Aufbau der Verbindungen gespeichert 
sind, d) jeder Knoten eine Oberwachungseinheit besitzt, die selbstandig prilft, ob eine Verbindung aufgebaut werden kann oder nicht. 
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Internes Bussystem fur DFPs, sowie Bausteinen mit zwei- oder 
mehrdimensionalen programmierbaren Zellstrukturen, zur 
Bewaltigung grolier Datenmengen mit hohem Vernetzungsaufwand. 



Hintergrund der Erfindung 
Stand der Technik 

... in Systemen mit zwei- oder mehrdimensionalen 
programmierbaren Zellstrukturen (FPGAs, DPGAs) 
In FPGAs und DPGAs befinden sich interne Bussysteme, die 
entweder global AnschluB an alle oder eine grofie Menge von 
Logikzellen haben oder eine lokale NextNeighbour-Verbindung 
aufweisen. Beiden Arten ist gemeinsam, daB es sich urn direkte 
Verbindungen zwischen zwei oder mehreren Logikzellen handelt. 
Weiterhin kann immer genau ein Signal den Bus benutzen, es sei 
denn, daB eine Multiplexerstruktur in eine Mehrzahl von 
Logikzellen zusammen mit einer Steuerung konfiguriert wird. 

... in DFP-basierenden Systemen 

In DFP-basierenden Systemen, nach DE 44 16 881 existieren die 
selben bereits beschriebenen Bussysteme. Zusatzlich existiert 
die Moglichkeit ein Bussystem zu trennen, so daB mehrere 
getrennt nutzbare Teilbusse entstehen. 

... in IO-Bussysteme nach DE 196 54 595.1-53 

In DE 196 54 595.1-53 wird ein IO-Bussystem beschrieben, das 
eine Vielzahl Bausteininterner Bussysteme, wobei ein Baustein 
ein FPGA, DPGA, DFP oder ahnlicher sein kann, zusammenfaBt und 
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aus dent Baustein herausfuhrt. Dabei konnen Speicherbaugruppen 
oder Peripherie oder weitere Bausteine oben genannter Gattung 
angesteuert werden. Es existiert nur ein Adressregister, bzw. 
ein Adresszahler urn die externen Adressen zu generieren. 

Probleme 

Die ublichen Bussysteme sind nicht dazu geeigner groBe 
Datenmengen in Form von byteweise oder anders gruppierten 
Signalen zu ubertragen. Besonders wenn die Bausteine zur 
Berechnung von Algorithmen verwendet werden ist es 
erf orderlich, daB eine Vielzahl von Daten (paketen) 
gleichzeitig zwischen den einzelnen konf igurierten 
Funktionsbereichen eines Bausteines ubertragen werden- In der 
ublichen Technik muB fur jeden Datenpfad, das ist die 
Verbindung (der Bus) zweier (oder mehrerer) Funktionsblocke, 
die dieselben Daten erhalten, eine direkte Punkt zu Punkt 
Verbindung aufgebaut werden, die dann ausschlieBlich den 
Datenverkehr zwischen eben diesen Funktionsblocken regelt. Es 
kann sich immer genau ein Datenpaket auf dem Bus befinden. Der 
Vernetzungsaufwand wird extrem hoch. Die Geschwindigkeir der 
heutigen internen Busse wird begrenzt durch die maximale 
Busbreite und die Laufzeit der Signale auf dem Bus. 
Beim in DE 196 54 595.1-53 beschriebenen IO-Bus kann pro 10- 
Zelle nur eine Art von Busverbindung aufgebaut werden, namlich 
ausschlieBlich die in dem Adressregister programmierte . Es 
besteht keine Moglichkeit auf verschiedene Datentypen oder 
Datensender zu reagieren und diese mit verschiedenen externen 
Bausteinen zu verbinden. 
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Verbesserung durch die Erfindung, Aufgabe 

Ziel der Erfindung ist es, ein Bussystem zu schaffen, das 
Daten zwischen einer Vielzahl von Funktionsblocken ubertragen 
kann, wobei sich mehrere Datenpakete gleichzeitig auf dem Bus 
befinden konnen. Dabei erkennt das Bussystem fur verschiedene 
Datentypen oder Datensender automatisch die richtige 
Verbindung und baut diese auf. 

Die Einzelheiten und besondere Ausgestaltungen , sowie Merkmale 
des erf indungsgemaften Bussystems sind Gegenstand der 
Patentanspruche . 

Beschreibung der Erfindung 

Ubersicht uber die Erfindung, Abstrakt 

Beschrieben wird- ein Bussystem, das horizontal, vertikal, 
diagonal oder in jeder beliebigen Lage auf einem Baustein 
integriert werden kann. 

Das Bussystem ist in eine Vielzahl von Segmenten unterteilt, 
wobei die Trennung der Segmente durch eine Bussteuerschaltung 
erfolgt. Diese Bussteuerschaltung wird Knoten genannnt. 
Gleichzeitig ubernimmt der Knoten das Routen, also das Steuern 
der Flulirichtung der Daten. Logikzellen oder PAE-Zellen nach 
DE 196 51 075.9-53 sind an die Knoten angeschlossen, sie 
senden und empfangen ihre Daten uber die Knoten, wobei jedem 
Datenpaket eine Zieladresse mitgegeben werden kann. Ebenfalls 
ist das Bussystem in der Lage uber LookUp-Tabellen, im 
Folgende Routingtabellen genannt, Zieladressen zu generieren, 
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hier2u kann vor all em das in DE 196 54 846.2-53 beschriebene 
Verfahren dienen. Die Bussysteme sind besonders zu einem 
direkten AnschlufJ an die in DE 196 54 595.1-53 beschriebenen 
INPUT-/OUTPUT-CELLS geeignet . Das Auf- und Abbauen von 
Verbindungen, sowie die Synchronisation der Daten erfolgt 
automatisch. Schlagt ein Aufbau fehl, da das benotigte 
Bussegment momentan belegt ist, wird der Aufbau zu einem 
spateren . Zeitpunkt wiederholt. Anhand unterschiedlicher 
Datentypen oder Datensender konnen automatisch 
unterschiedliche Verbindungen aufgebaut werden. 

Detailbeschreibung der Erfindung 
Das Bussystem 

Auf einem Baustein befinden sich eine Vielzahl von Bussen, die 
horizontal, vertikal, diagonal oder in jeder beliebigen Lage 
auf dem Baustein angeordnet sind. Dabei sind die einzelnen 
Busse nicht durchgehend von einer Bausteinkante zur anderen, 
sondern sie sind in eine Mehrzahl von Bussegmenten unterteilt. 
Die Bussegmente werden durch die nachfolgend beschriebenen 
Knoten getrennt. Jedes Bussegment ist unabhangig von den 
anderen nutzbar und verschaltbar, wobei die Verschaltung von 
den Knoten ubernommen wird. Auf dem Bussystem ist kann ein 
eigenes Protokoll implementiert sein, das von den Knoten 
verwaltet wird; ebenfalls ist denkbar, dafl das Protokoll von 
den Zellen, die den Bus benutzen, verwaltet wird und die 
Knoten nur passive Schalter sind. 
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Der Knoten 

Ein Knoten dient der Verschaltung der einzelnen Bussegmente 
miteinander . Ebenfalls wird das Aufschalten der Zellen auf die 
Bussegmente von den Knoten ubernommen. 

In einem Knoten sind die Bussegmente aller Richtungen 
zusammengef iihrt , das bedeutet, 

- in einem zweidimensionalen System werden die 3usse aus 4 
Richtungen Norden (N) , Sliden (S) , Osten (E) , Westen (W) auf 
den Knoten gefuhrt. 

- in einem dreidimensionalen System werden die Busse aus 6 
Richtungen Norden (N) , Sliden (S) , Osten (E) , Westen (W) , Oben 
(T) , Unten (B) auf den Knoten gefuhrt. 

- in einem n-dimensionalen System werden die Busse aus n- 
Richtungen (je Dimension existiert ein Richtungsvektor dessen 
Richtung durch das Vorzeichen bestimmt wird => pro Dimension 
existieren zwei Richtungen, die durch das Vorzeichen des 
Richtungsvektors unterschieden werden) auf den Knoten gefuhrt. 

Knoten Typ A 

Innerhalb des Knotens befindet sich ein Bussystem, auf das die 
externen Busse auf geschaltet werden und das somit aus mehreren 
Sammelschienen besteht. Ein externer erster Bus wird uber ein 
Tor auf eine Sammelschiene auf geschaltet , Uber ein weiteres 
Tor wird die Sammelschiene auf den externen zweiten Bus 
auf geschaltet . Urn Broadcasting, das Versenden von Daten an 
mehrere Empfanger, zu ermoglichen, konnen auch mehrere 
"zweite" Busse auf das interne Bussystem geschaltet werden. 
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Die Tore konnen dabei als rein passive Schalter, als 
Bustreiber oder als Register/Latch ausgestaltet sein. 

Weiterhin hat der Knoten Zugriff auf eine (oder mehrere) mit 
ihm verbundene (n) konf igurierbaren Elemente (Zellen) . Diese 
verbindet er gegebenenf alls mit einem oder mehreren der 
angrenzenden Bussegmente . 

Knoten Typ B 

Im Gegensatz zum Knoten Typ A existiert kein internes 
Bussystem. Der Knoten besteht aus n konf igurierbaren 
Schalnern, die jedes angrenzende Segment mit jedem anderen 
angrenzenden Segment verbinden konnen. Beispielsweise gilt bei 
2-dimensionalen Strukturen n=6. 



N 


Verbindung 


1 


O-W/W-0 


2 


N-S/S-N 


3 


N-0/O-N 


4 


O-S/S-O 


5 


S-W/W-S 


6 


W-N/N-W 



(N=Nord, 0=Ost, S=Sud, W=West) # 

Ein Schalter kann unidirektional oder bidirektional 
ausgestaltet sein, dabei kann er ein Register oder Latch zur 
Speicherung der Daten enthalten. 
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Das "gewohnliche" Routingverf ahren 

Eine Verbindung wird initiiert von einem Datensender (DS) 

dies ist ein konf igurierbares Element (Logikzelle, Buszelle 

(auch Externe gemafi DE 196 54 595.1-53)) , der eine 

Verbindung zu einem Datenempf anger (DE) der ebenfalls aus 

einem konf igurierbaren Element besteht benotigt. Hierzu 

teilt der DS dem Knoten seine Busanf orderung mit. Der erste 
Knoten direkt nach einem Datensender wird Initiator-Knoten 
genannt. Der entnimmt, wie nachfolgend beschrieben, einer 
internen Tabelle die Adresse des nachsten fur den 
Datenrransf ers benotigten Knotens. 

Sofern der Knoten in der Lage ist, das erste benotigte 

Bussegment anzusprechen das ist immer dann moglich, wenn 

das Bussegment UND eine interne Sammelschiene des Knoten frei 

ist baut er die Verbindung auf, ansonsten weist er die 

Anforderung des DS zuruck und der DS versucht den Zugriff zu 
einem spateren Zeitpunkt noch einmal, oder wartet und halt die 
Zugriff sanf orderung weiter aufrecht, bis der Knoten sie 
aktzeptiert . 

Jeder nachfolgende Knoten entnimmt wiederum die Adresse des 
nachsten Knotens aus seiner internen Tabelle und setzt den 
Aufbau der Verbindung fort. Ist der Knoten nicht in der Lage 
den Aufbau der Verbindung durchzuf uhren (entweder ist das 
benotigte Bussegment besetzt oder die Sammelschiene des 
Knotens ist nicht frei) , so kann er entweder in einen 
Wartezustand springen, oder den Aufbau unterbrechen und einen 
Fehler an den Initiator-Knoten zuriickmelden . 
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Erst wenn eine Verbindung komplett aufgebaut ist, werden die 
Datenpakete ubertragen und der Sender erhalt erhalt die 
Quittierungssignale fur den Datenaustausch (vgl. rACK in DE 
196 51 075.9-53). Dadurch wird der Datentransf er automatisch 
mit den Datensendern synchronistiert . Schlagt der 
Verbindungsaufbau fehl und mufJ er zu einem spateren Zeitpunkt 
wiederholt werden, erhalt der Datensender kein 
Quittierungssignal, somit gehen keine Daten verloren. 

Ist die Verbindung komplett aufgebaut, bleibt sie so lange 
quasi-permanenc (das bedeutet, sie erscheint dem DS und DE wie 
eine direkte Verbindung) stehen, bis der DS die Verbindung 
durch eine Meldung an den Init iator-Knoten wieder auf lost. 
Es ist denkbar ein Timeout-Verf ahren zu implementieren, das 
eine stehende Verbindung nach einer gewissen Zeit unterbricht, 
ins besondere dann, wenn langere Zeit kein Datentransf er 
stattgefunden hat, urn die Bussegmente fur andere Verbindungen 
f reizugeben. 

Das erweiterte Routingverf ahren 

Beim bisher beschriebenen Verbindungsaufbau befinden sich die 
Adressen nur wahrend der Aufbauphase auf dem Bus. Wahrend der 
Datenubertagen werden die Adressen nicht mehr ubertragen. 
Beim Verfahren des erweiterten Verbindungsauf baus laufen die 
Adressen standig auf separaten Leitungen mit den Daten mit. 
Dabei existieren zwei Adressierungsschemata : 
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1 . Raumkoordinaten 

Als Adressen werden die Raumkoordinaten des Ziels angegeben. 
Die Raumkoordinaten sind von der gewahlten Dimension des 
Systems abhangig. Beispielsweise benutzt ein 3-dimensionales 
System die Koordinaten X/Y/Z und ein 2-dimensionales X/Y. 
Prinzipiell ist das Verfahren auf ein beliebig dimensionales 
System anwendbar. Jeder Koordinate ist ein Richtungsvektor 
zugeordnet, der angibt, ob sich die Daten/der 
Verbindungsauf bau in positiver oder negativer Richtung 
bewegen/bewegt . 

Die Daten bewegen sich vom Ursprungsknoten in eine der 
eingesrellten Richtungen, Dabei wird die ent sprechende 
Richtungskoordinate beim Durchlauf eines Knotens so 
modifiziert, daft 

- bei Bewegung in positiver Richtung 1 subtrahiert wird 

- bei Bewegung in negativer Richtung 1 addiert wird 

Die Zielachse ist erreicht, wenn die Koordinate 0 ist, der 
Zielknoten ist erreicht, wenn alle Koordinaten 0 sind. 

Es ist implementierungsabhangig, ob ein zweier-Komplement 
generiert wird und eine Koordinate als negative Zahl 
dargestellt wird (auf die aufaddiert wird) oder ob von einer 
positiven Zahl subtrahiert wird. Ebenfalls kann auf eine 
positive Zahl so lange aufaddiert werden, bis ein Uberlauf 
generiert wird, der die Zielposition kennzeichnet . 

Es gibt zwei sinnvolle Strategien die Laufrichtung der Daten 
festzulegen: 
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a. Statisches Verfahren: Die Daten laufen immer in dieselbe 
Richtung, d.h. es wird versucht immer die Richtung 
beizubehalten, so lange, bis ein Richtungswechsel unbedingt 
erforderlich ist. Ein Richtungswechsel ist erf orderlich, wenn 
die aktuelle Richtungskoordinate gleich null ist, d.h. deren 
Zielposition erreicht wird. 

Wird die Zielposition einer Koordinate erreicht, werden die 
Daten in Richtung der Koordinaten bewegt, die ungleich 0 sind. 
Sind aile Koordinaten gleich null, ist der Zielknoten der 
Daten erreicht. 

b. Dynamisches Verfahren. Die Daten werden beliebig in eine 
der mcglichen Richtungen bewegt, wobei die Bewegung immer in 
die vom Richtungsvektor vorgegebene Richtung erfolgt. Dabei 
bedeutet eine beliebige Bewegung, daft die Daten immer zu dem 
Knoten weitergeleitet werden, zu dem am wenigsten Verkehr 
herrscht. Es wird also versucht immer den Weg der geringsten 
Kollisionen und Blockaden zu gehen. Dadurch kann das Verfahren 
u-U. schneller und bei groiien Systemen geeigneter sein. 

2. Adress-Lookup 

Werden Lookup-Adressen ubertragen, wird der jeweils nachste 
Knoten in jedem Knoten neu bestimmt. Dies geschieht indem in 
den nachfolgend beschriebenen Routingtabellen der Eintrag der 
Lookup-Adresse ausgelesen wird und so die Daten fur das 
nachste Ziel festgelegt werden. Dieses Ablauf ist gleich wie 
im "gewohnlichen" Routing-Verf ahren . 
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Der Vorteil der Raumkoordinaten liegt darin, daft kein Lookup 
in einer Tabelle benotigt wird und somit weniger 
Verwaltungsaufwand anfallt. 

Der Vorteil des Adress-Lookup liegt in seiner Flexibilitat und 
der genauen Vorhersagbarkeit der Verbindung. 

Teilweise kann es sinnvoll beide Verfahren miteinander zu 

mischen. Dazu miissen beide Adressen (Raumkoordinaten und 

Lookup-Adressen) gleichzeitig ubertragen werden. 

Sind die Raumkoordinaten nicht null, werden die Daten anhand 

der Raumkoordinaten ubertragen, Sobald die Raumkoordinaten 

null erreichen, wird in der aktuellen Routingtabelle ein 

Lookup an Stelle der Lookup-Adresse durchgef uhrt . 

Dadurch ist flexibel einstellbar uber welchen Segmenten die 

Daten per Lookup-Verf ahren oder Raumkoordinaten-Verf ahren 

iibertragen werden . 

Die Buszustande des erweiterten Routingverf ahrens 
1 . Quasi-permanent 

Eine Verbindung kann ahnlich zum "gewohnlichen" 

Routingverf ahren quasi-permanent aufgebaut werden. Dabei wird 

jeder Knoten, den ein erstes Datum durchlauft permanent gemali 

den Adressen die die diesem Datum zugeordnet sind 

f reigeschaltet • Die Freischaltung bleibt fur alle 

nachf olgenden Daten so lange auf rechterhalten, bis ein Abbruch 

der Verbindung durchgefuhrt wird. Obwohl ein derartiger Aufbau 

im erweiterten Routingverf ahren nicht zwingend notwendig ist, 

bietet er zwei Vorteile: 

i. Die Durchlauf zeit der Daten wird erheblich verringert. 
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ii. Zeitverluste durch Arbitrierung werden vermieden. 

2. Registered 

Dies ist der normale Buszustand. Eingehende Daten werden 
zunachst in einem Register zwischengespeichert . Beim Schreiben 
in das Register, wird ein Quittierungssignal an den sendenden 
Knoten geschickt. Daten werden nur in das Register 
geschrieben, wenn dieses leer ist, d.h. entweder vorher keine 
Daten in das Register geschrieben wurden oder die vorher 
geschriebenen Daten bereits weiterubertragen sind. Ist das 
Register nicht leer, wird so lange gewartet una kein 
Quittierungssignal erzeugt, bis das Register leer ist. Die 
Register werden arbitriert und das Register mit der momentan 
hochsren Prioritat wird ubertragen. Die Arbitrierung und 
Ubertragung findet zyklisch mit jedem Takt start* Diese 
Methode eignet sich vor allem fur Ubertragungskanale auf denen 
Daten vieler verschiedener Quellen zeitunkritisch ubertragen 
werden mussen. Diese Methode wird quellenoptimiert genannt . 

3. Segmentiert 

Ein segmentierter Obertragungskanal besteht aus quasi- 
permanenten und register-orientierten Knoten. Dabei ist der 
Obertragungskanal stellenweise geschwindigkeitsoptimiert 
quasipermanent und an anderen Stellen quellenoptimiert 
ausgestaltet . 
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Die Routingtabellen 

Grundbaustein eines Knotens ist eine Routing-Tabelle, ahnlich 
der in DE 196 54 846.2-53 beschriebenen Switching-Tabellen . 

Der mogliche Aufbau einer solchen Tabelle ist wird anhand 
eines Ausf uhrungsbeispieles beschrieben: 



Tor 


EALU 


Bus 


Eintrag 
Position 
in 

Zieltabel 
le 


Lauf zeit 


Auf bauzeit 


1 


2 


3 


4 


0 
1 


0 
2 


R 
1 


R 
2 


1 


0 


a . . 0 


b. .0 


c. . 0 











































































































Jede Zeile stellt eine gultige Verbindung dar. Dabei konnen 
mehrere \ferbindungen gleichzeitig aktiv sein, maximal so viel 
Verbindungen, wie freie interne Sammelschienen und freie 
externe Bussegmente existieren. Eine nachfolgend beschriebene 
Oberwachungslogik ubernimmt die Prufung, ob eine neu 
ausgewahlte Verbindung aufgebaut werden kann. 
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Jede Zeile wird uber ihre binare Adresse angesprochen und 
ausgewahlt. Weiterhin gibt es Sonderzeilen, die keine binare 
Adresse besitzen, sondern uber Triggerssignale oder 
Zustandssignalen selektiert werden. Zu diesen Signalen gehoren 
(vgl. DE 196 51 075.9-53) 

- rRDYl, rRDYh 

- oACKl, OACK2 

Hierbei werden Busverbindungen zu den Datenempf angern (rRDY) 
automatisch immer dann aufgebaut, wenn die Datensender-Zelle 
gultige Ergebnisse besitzt. Bei den Signalen oACK ist der 
Empf anger-/Senderablauf vertauscht. Der Datenempf anger baut 
die Verbindung zu seinem Datensender auf, sobald der 
Datenempf anger seine Operanden abgearbeitet hat und in der 
Lage ist neue Operanden zu verarbeiten. 

In den Spalten Tor werden die fur die j eweilige Verbindung 
aktiven Tore eingetragen, dabei ist es moglich, daft nur ein 
Tor markiert ist und in den Spalten EALU eine Verbindung zu 
einem konf igurierbaren Element (einer oder mehrerer Zellen) 
zum Beispiel zu einem R-REG oder O-REG (vgl. DE 196 51 075.9- 
53) gewahlt wird. 

In der Spalte Bus wird die fur diese Verbindung verwendete 
interne Sammelschiene ausgewahlt, dabei ist der Wert binar, so 
daft in der beschriebenen Tabelle insgesamt 4 interne 
Sammelscheinen benutzt werden konnnen. Die Auswahl der 
internen Sammelschienen kann auch entfallen, in dem ein 
Prioritatsdekoder die erste freie Sammelschiene erkennt und 
diese automatisch zuteilt. 
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In der Spalte Eintrag Position in Zieltabelle wird die Adresse 
der Zeile der Tabelle angegeben, die den Knoten steuert, zu 
dem Verbindung auf genommen wird. An dieser Adresse stehen die 
fur die aktuelle Verbindung benotigten Routinginf ormationen im 
nachsten Knoten. 

Die Spalte Laufzeit ist optional. Darin kann die erwartete 
Signallauf zeit vom DS zum DE angegeben werden. Diese 
Information kann fur Berechungen des Datendurchsat zes oder zur 
Generierung eines Timeout verwendet werden. 

Die Spalte Aufbauzeit ist optional. Darin kann die maximale 
Zeit zum Aufbauen der Verbindung zum nachsten Knoten (oder der 
gesamten Verbindung vom DS zum DE) angegeben werden. Wird 
diese Zeit uberschritten kann uber einen Timeout der 
Verbindungsaufbau abgebrochen werden und die Bussegmente und 
Knoten werden fur andere Verbindungen frei. 
Zu einem spateren Zeitpunkt versucht der DS erneut die 
Verbindung herzustellen . 

Die Eintrage in der Routingtabelle konnen gemafi bekannten 
Verfahren_ (DE 196 51 075.9-53, DE 196 54 846.2-53) von einer 
Ladelogik konfiguriert und umkonf iguriert werden. 

Wird das "erweiterte" Routingverf ahren verwendet, mussen die 
Raumkoordinaten den Routingtabellen hinzugefugt werden. 
Ebenfalls wird eine Prioritatskennung erwartet. 
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Die Prioritatskennung gibt Auskunft, wie relevant ein Kanal 
fur die Leistung eines Bausteines ist. 1st die 
Prioritatskennung sehr hoch, steigt die Relevanz des Kanales. 
Dabei kann die Kennung auf drei Arten ausgelegt werden: 

1. Timeout 

Die Kennung gibt an, nach wievielen ungenutzten Taktzyklen der 
Kanal abgerissen werden soil, also nach wievielen Zyklen eine 
DISCONNECT generiert wird* 

2. Paket-Grofte 

Die Kennung gibt an, nach wievielen Datenpaketen ein 
DISCONNECT generiert wird. 

3. Takt-Zyklen 

Die Kennung gibt an, nach wievielen Taktzyklen ein DISCONNECT 
generiert wird. 

Dabei kann fest eine der 3 moglichen Arten implement iert 
werden, oder mittels einer zusatzlichen Angabe eine Art 
ausgewahlt werden. 



Die Prioritatsart (Prioart in der nachstehenden Tabelle) wird 
in der nachfolgen beispielsweise aufgefuhrten Routingtabelle 
wie f olgt ausgewertet : 



Bit-Kombination 


Prioritatsart 


00 


Timeout 


01 


Paket-Grolie 


10 


Takt-Zyklen 


11 


permanent 
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Permanent kann auch dargestellt werden, indem ein Wert der 
Prioritatskennung fest als "permanent" vorgegeben ist. Dafur 
eignet sich fur gewohnlich besonders der Maximalwert der 
Prioritatskennung oder null. 





Tor 


EALU 


Bus 


Eintrag 
Position 
in Ziel- 
tabelle 


Y/X Raum- 
koordinate 

und 
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Prio 
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0 
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0 
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R 
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R 
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k. . 0 


m. . 0 


n. . 0 
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0 
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Der Arbiter 

Der Routingtabelle vorgeschaltet ist ein Arbiter, die aus der 
Menge der Anfragen zum Verbindungsauf bau iiber die 
Routingtabelle einige Signale auswahlt. Dabei ist es sinnvoll 
den Arbiter aus einem gewohnlichen Priority-Logik und einem 
sogenannten Round-Robin-Arbiter nach dem Stand der Technik (er 
schaltet die hdchste Prioritat auf einer Zeitscheibe immer dem 
nachsten Signal zu, das bedeutet, das Signal, das momentan die 
hochste Prioritat hat, wird als nachstes die Niederste 
besitzen und dann mit jedem Zugriff eine Hohere erhalten) 
aufzubauen. Dabei kann die Priority-Logik dazu dienen einigen 
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Signalen, wie zum Beispiel rACK, oRDY grundsat zlich eine 

besonders hohe oder besonders niedere Prioritat 

zuzuordnen. Der Round-Robin-Arbiter sorgt dafur, daft ein 
angef orderter Verbindungsauf bau, der soeben nicht aufbaubar 
war, die niederste Prioritat erhalt und somit wartet, bis alle 
anderen Verbindungsanf orderungen entweder aufgebaut oder 
iiberpriift wurden. 

Die Zustandsmaschine (Steuerung) 

Eine Zustandsmaschine steuert die internen Ablaufe im Knoten. 
Dabei ist die Zustandsmschine zweigeteilt: 

- Die Steuerung des Knotens 

- Die Steuerung des Bustransfers und der Synohronistat ion . 
Dabei kann auf eine Zustandsmaschine ahnlich der in DE 196 51 
075.9-53 beschriebenen zuriickgegrif f en werden. 

Die Zustandsmaschine (n) sind gemafi dem Stand der Technik 
implementierbar und werden nicht nahers beschrieben. 

Die Uberwachungseinheit 

Eine Uberwachungseinheit ist der Routingtabelle 
nachgeschaltet . Sie entnimmt die in eine adressierte Zeile 
eingetragenen Daten und uberpriift ob der Verbindungsauf bau 
moglich ist. 

Dabei werden vor allem folgende Punkte uberpriift: 

- Steht eine freie interne Sammelschiene zur Verfugung. 

- Ist das angef orderte Tor frei. 
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- 1st das angef orderte externe Bussegment frei. 

a) 1st die Oberprtifung positiv, wird das Signal ACCEPT 
generiert und an die Zustandsmaschinen, sowie die, den 
Verbindungsaufbau anfordernde Einheit, gesendet, um einen 
erf olgreichen Aufbau zu signalisieren . 

b) 1st die Uberprufung negativ, wird das Signal REJECT 
generiert und an die Zustandsmaschinen, sowie die, den 
Verbindungsaufbau anfordernde Einheit, gesendet, um einen 

f ehlgeschlagenen Aufbau zu signalisieren. Auf dieses Signal 
kann der oben beschriebene Arbiter reagieren und die Prioritat 
dieser Anforderung auf die Niederste setzen. 

Verbindungsabbau 

Eine bestehende Verbindung kann durch verschiedene Kriterien 
wieder abgebaut werden. Zu den wichtigsten Kriterien zahlen: 
Timeout: Eine Verbindung wird abgebaut, da uber eine langere 
Zeitspanne kein Datentransf er stattgef unden hat. Ein Timeout 
kann einfach uber einen ladbaren Abwartszahler implementiert 
werden. Der Zahler wird bei jedem ubertragenen Datum neu mit 
einem festen Ausgangswert , der die Zeitspannne bis zum Timeout 
reprasentiert, geladen. Findet kein Datentransf er statt, zahlt 
er mit jedem Bustakt um eins herunter. Kommt er bei null an, 
ist die maximale Zeitspanne abgelaufen und der Bus wird 
abgebaut . 

Datenzahler: Ein ladbarer Zahler wird mit der zu ubertragenden 
Anzahl von Daten geladen. Bei jedem Datentransf er zahlt der 
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Zahler urn eins herab. Kommt der Zahler bei null an, sind alle 
Daten ubertragen und der Bus wird abgebaut. 

Synchronisationssignale (vgl. DE 197 04 728.9, RECONFIG): Der 
Busabbau wird durch die Status- und/oder 
Synchronisationssignale der Zelle(n) gesteuert, die als 
Datensender auftreten. Zeigen die Zellen beispielweise an, dafi 
ihre Datenverarbeitung beendet ist oder daft sie umkonf iguriert 
werden konnen, wird der Bus abgebaut, da er nicht mehr 
benotigt wird. Zu diesen Signalen gehoren auch rRDY, oACK. 

Der Verbindungsabbau geht dabei so vonstatten, dafi vom 
Initiator-Knoten aus ein Signal zum Abbauen der Verbindung 
gesendet wird Jeder weitere Knoten sendet das empfangene 
Signal an seine (n) Partner knoten weiter und lost die 
Verbindung sofort auf. 

Im erweiterten Routingverf ahren werden quasi-permanente Busse 
entweder durch das RECONFIG-Synchronisat ionssignal (vgl. DE 
197 04 728,9) oder gemali der Prioritatskennung abgebaut. Wird 
das Ende einer Verbindung gemafi der Prioritatskennung von 
einem Knoten f estgestellt , wird von ihm das DISCONNECT- Signal 
zum Abbruch des Busses generiert und an alle anderen Knoten 
weitergeleitet . Die Knoten reagieren auf ein DISCONNECT wie 
auf ein RECONFIG. 

Bei register-orientierten Knoten ist ein Verbindungsabbau 
nicht notwendig, da eine Verbindung dynamisch mit den 
eintref f enden Daten gemafl der zugeordneten Adressen aufgebaut 
wird. Nach dem Weiterleiten der Daten ist die Verbindung 
automatisch abgebaut und fur andere Ubertragungen frei. 

20 



WO 98/35294 



PCT/DE98/00456 



Broadcasting 

In DE 196 51 075.9-53 ist ein Bussystem beschrieben, das das 
Senden eines Datenpaketes an mehrere Empfanger erlaubt und 
ebenfalls eine Quittierung des Datentransf ers ermoglicht. 
Dasselbe System kann bei dem hier beschriebenen Verfahren 
verwendet werden. Es ist ohne weiteres moglich, mehrere Tore 
auf eine Sammelschiene zu schalten. Dabei wird nur eine Zeile 
in der Routingtabelle verwendet- Die Adresse innerhalb der 
Zielroutingtabellen Eintrag Position in Zieltabelle muft dabei 
bei jeder der selektierten Routingtabellen zwangslaufig 
dieselbe sein. 

Um dieses Problem zu umgehen, ist es moglich mehrere Eintrage 
fur als Eintrag Position in Zieltabelle zur Verfugung zu 
stellen. Beispielsweise konnte fur jedes Tor ein separater 
Eintrag Position in Zieltabelle existieren. Damit ist jedem 
Tor eine Adresse innerhalb der Zielroutingtabelle zugeordnet. 

Die Quittierung erfolgt genau wie in DE 196 51 075.9-53 
beschrieben uber Signalleitungen, die von Open-Kollektor- 
Treiber g_etrieben werden und mit einem Transistor 
abgeschlossen sind . 

Um eine bessere Implementierbarkeit in existierende Chip- 
Technologien zu ermoglichen konnen Quittierungssignale in 
einem Knoten zunachst maskiert und danach logisch miteinander 
verkmipft werden. Die logische Verknupfung wird an den 
nachsten Knoten weitergeleitet . Findet beispielsweise in alien 
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durchlauf enden Knoten eine logische UND-Verknupf ung der 
Quittierungssignale statt, ist das Resultat dasselbe, wie bei 
einer Open-Kollektor-Schaltung . 

Ladelogik (PLU) 

Eine Ladelogik im Sinne von DE 44 16 881 Al ist an die 
Routingtabelle angeschlossen . Uber diese kann die 

Routingtabelle Equivalent zu den Switchingtabellen aus DE 

196 54 846.2-53 konfiguriert und umkonf iguriert werden. 

Die Routingtabellen konnen urn eine Spalte erweitert werden, 
die benutzt wird urn Ruckmeldungen an die Ladelogik zu senden, 
wenn die in der betreffenden Zeile angegebene Verbindung auf- 
oder abgebaut wird. So kann in der Spalte angegeben werden, ob 
eine Ruckmeldung an die PLU erfolgen soil, wenn die Verbindung 
auf- oder abgebaut wird, sowie welcher Art die Ruckmeldung 
ist. Die Ruckmeldung erfolgt gemaft DE 196 51 075.9-53 Figur 
15, wobei statt des Latches 1504 ein Tor eingeserzt ist, das 
je nach Einstellung entweder beim Verbindungsauf bau oder - 
abbau durchschaltet und die Ruckmeldung an die Transistoren 
(1502), die als Open-Kollektor-Treiber geschaltet sind 
ansteuern . 
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Kurzbeschreibung der Diagramme 

Fig. 1 Zeigt einen zweisimensionalen Baustein mit Zellarray 
und Knoten. 

Fig. 2 Zeigt einen Ausschnitt aus Fig. 1. 

Fig. 3 Zeigt mehrere bestehende Busverbindungen und den Auf bau 
neuer Verbindungen . 

Fig. 4 Zeigt den Auf bau neuer Busverbindungen. 

Fig. 5 Zeigt den nachsten Schritt des Verbindungsauf baus . 

Fig. 6 Zeigt die Kollistion zweier Busse. 

Fig. 7 Zeigt den schrittweisen Verbindungsabbau nach einer 
Kollision^ 

Fig. 8 Zeigt den schrittweisen Verbindungsabbau nach einer 
Kollision. 

Fig. 9 Zeigt den schrittweisen Verbindungsabbau nach einer 
Kollision. 

Fig. 10 Zeigt den schrittweisen Verbindungsabbau nach einer 
Kollision . 
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Fig. 11 Zeigt den Neuaufbau der abgebauten verbindung nach 
einer gewissen Zeitspanne. 

Fig. 12 Zeigt die Fortsetzung von Fig. 6, wenn der Knoten mehr 
als eine Sammelschiene besitzt und somit keine Kollision 
stattfindet. 

Fig. 13 Zeigt die Verbindung der Bussegmente mit den 
Sammeischienen eines Knotens. 

Fig. 14 Zeigt den Datentransf er eines Verbindungsauf baus . Die 
Unterfiguren zeigen den Zustand der Verbindung jeweils im 
Abstanden von einem Buszyklus. 

Fig. 15 Zeigt den Datentransf er eines Verbindungsabbaus . Die 
Unterfiguren zeigen den Zustand der Verbindung jeweils im 
Abstanden von einem Buszyklus. 

Fig. 16 zeigt die Steuereinheit eines Knotens. 

Fig. 17 Zeigt das Broadcasting an mehrere Datenempf anger . 

Fig. 18 zeigt eine gegeniiber Figur 16 verbesserte 

Steuereinheit eines Knoten mit Kollisionsdetektoren . 

Fig. 19 zeigt eine gegeniiber Fig. 16 verbesserte 

Routingtabelle mit Ansteuerung der Fig. 18. 

Fig. 20 zeigt die zu Fig. 18/19 passenden Sammeischienen. 

Fig. 21 zeigt ein gegeniiber Fig. 17 verbessertes Broadcasting 

an mehrere Knoten. 

Fig. 22 zeigt die Ablauf steuerung der Fig. 18-21. 
Fig. 23 zeigt einen Busknoten gemafi dem erweiterten 
Routingver f ahren . 

Fig. 24 zeigt eine optimierte Variante von Fig. 23. 
Fig. 25 zeigt ein Datenregister mit Synchronisat ionseinheit . 
Fig. 26 zeigt einen Kollisionsdetektor nach dem erweiterten 
Routingver f ahren . 
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Fig. 27 zeigt die Steuereinheit fur Fig. 23-26. 

Fig. 28 zeigt einen durchsat zsteigernden, kaskadierbaren 

Zusatz zu Fig. 27. 

Fig. 29 zeigt die Steuerregister fur Fig. 27 (2705) . 

Fig. 30 zeigt einen Busaufbau liber relative Raumkoordinaten 

gemall dem erweiterten Routingverf ahren . 

Fig. 31 zeigt einen Busaufbau uber absolute Raumkoordinaten 

gemafi dem erweiterten Routingverf ahren . 

Fig. 32 zeigt die Verwaltung der Raumkoordinaten. 

Fig. 33 zeigt einen segmentierten Busaufbau. 

Detailbeschreibung der Diagramme 

Figur 1 zeigt einen Baustein der Gattungen FPGA, DPGA, DFP (DE 
44 16 881 Al) . Der Baustein ist zweidimensional symmetrisch 
aus konf igurierbaren Zellen (0101) aufgebaut, dabei kann 0101 

auch eine Mehrzahl von auch unterschiedlichen 

konf igurierbaren Zellen, die zu einer Gruppe zusammengef aJJt 
und unrereinander vernetzt sind, reprasentieren. Zwischen den 
Zellen befinden sich die Knoten des Bussystemes (0102) . Dabei 
sind mehrere Knoten gekennzeichnet , die im folgenden 
Ausfiihrungsbeispiel mehrere Verbindugnen aufbauen werden. Der 
Datensender A (0103) wird im Folgenden eine Verbindung zum 
Datenempf anger A (0104) aufbauen, sowie der Datensender B 
(0106) mit dem Datenempf anger B (0105) . Eine ausschnittsweise 
Vergrofterung (0107) ist in Fig. 2 dargestellt. 
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Figur 2 zeigt einen Ausschnitt aus einem Baustein 
beschriebener Gattung. Die konf igurierbare (n) Zelle(n) aus 
Fig. 1 (0101) sind in 0201 dargestellt . Ein Bundel (0203) aus 
einer Vielzahl von Leitungen (die Anzahl ist beliebig und 
nicht exakt dargestellt) verbindet 0201 mit einem Knoten 0202. 
Die Knoten (0202) sind uber die Bussegmente (0205) miteinander 
verbunden. Ebenfalls haben die Knoten uber die Bussegmente 
0206, deren Ausgestaltung dieselbe wie die der Bussegmente 
0205 ist, Anschlufi an die sich aufierhalb der Vergrolierung 
befindenden Knoten. Ober das optionale Leitungsbiindel (0204) 
wird verdeutlicht , dali die konf igurierbare (n) Zelle(n) auch 
uber mehrere unterschiedliche Leitungsbiindel an eine Mehrzahl 
von Knoten (0202) angeschlossen sein kann/konnen. 

Figur 3 zeigt den Baustein zur Laufzeit. 
Es existieren mehrere Verbindungen : 

- zwischen den Knoten Z (0301) 

- zwischen den Knoten Y (0306) 

Der Datensender A (0302) versucht eine Verbindung (0303) zum 
Datenempf anger A (0307) aufzubauen. Die Verbindung wird jedoch 
zuruckgewiesen (REJECT), da sie beim Knoten Z (0308) biockiert 
ist. Gleichzeitig baut der Datensender B (0304) ein Bussegment 
(0305) zu seinem Empfanger auf. Dieser Versuch gelingt, da der 
angesprochene Knoten und das benotigte Bussegment nicht 
biockiert ist. 

Figur 4 zeigt den nachsten Buszyklus. Die Verbindungen Y und Z 
sind zwischenzeitlich abgebaut. Der Datensender A (0401) kann 
nun das Bussegment (0403) aufbauen, da der Knoten (0402) nicht 
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mehr blockiert ist Gleichzeitig baut der Datensender B (0404) 
das bereits bestehende Bussegment (0405) liber den Knoten 
(0406) hinaus aus => Das neue Bussegment (0407) wird 
auf gebaut . 

Figur 5: Der in Fig. 3 begonnene und liber Fig. 4 fortgesetzte 
Busaufbau setzt sich Equivalent zu Fig. 4 fort. 

Figur 6: Der Verbindungsaufbau des Bussegmentes 0602 des 
Datensenders B schlagt fehl. Der Knoten 0601 ist besetzt und 
liefert ein REJECT-Signal, das das Fehlschlagen des 
Verbindungsaufbaus signalisiert und den Abbruch der Verbindung 
bewirkt, an den Knoten 0603. 

Figur 7 zeigt den kompletten Verbindungsaufbau zwischen dem 
Datensender A (0701) und dem Datenempf anger A (0702). Die 
Verbindung des Datensenders B wird weiter abgebaut . Der Knoten 
0703 liefert liber das Bussegment (0704) das REJECT-Signal an 
den Knoten 0705. Daraufhin wird das Segment 0704 abgebaut. 

Figur 8: Der Datentransf er zwischen dem Datensender A und dem 
Datenempf anger A beginnt. Die Verbindung des Datensenders B 
wird weiter abgebaut. Der Knoten 0801 liefert liber das 
Bussegment (0802) das REJECT-Signal an den Knoten 0803. 
Daraufhin wird das Segment 0802 abgebaut. 

Figur 9: Der Datentransf er zwischen dem Datensender A und dem 
Datenempf anger A setzt sich fort. Das letzte Segment des 
Datensenders B wird abgebaut. Der Knoten 0901 liefert uber das 
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Bussegment (0902) das RE JECT- Signal an den Knoten 0903. 
Daraufhin wird das Segment 0902 abgebaut . 

Figur 10: Der Datentransf er zwischen dem Datensender A und dem 
Datenempf anger A setzt sich fort. Der Datensender B (1001) 
wartet eine Zeitspanne ab, bis er erneut versucht eine 
Verbindung zu seinem Datenempf anger aufzubauen. 

Figur 11 zeigt den Zustand mehrere Buszyklen spater: Der 
Datentransf er zwischen dem Datensender A und dem 
Datenempf anger A findet immer noch statt. Der Datensender B 
(1101) startet einen neuen Versuch die verbindung zu seinem 
Datenempf anger aufzubauen. Er baut ein Bussegment (1102) zum 
Knoten (1103) auf. Sofern in den nachsten Buszyklen die 
Verbindung des Datensenders A zu seinem Datenempf anger A 
abgebaut ist, gelingt der Verbindungsauf bau des Datensenders B 
(1101), ansonsten schlagt sie wie in Fig. 6 beschrieben erneut 
fehl. 

Figur 12 zeigt die Fortsetzung der Fig. 6, wenn der Knoten 
1202 in der Lage ist mehr als eine Verbindung aufzubauen, das 
heilit, der Knoten besitzt mehrere interne Sammeischienen. 
Dadurch kann die Verbindung des Datensenders A uber die erste 
Sammelschiene abgewickelt werden und die Verbidnung des 
Datensenders B uber die Zweite. Der Knoten 1202 baut das 
Bussegment 1203 zu dem Datenempf anger B (1201) auf. 

Figur 13 stellt eine knoteninterne Vernetzungsstruktur dar. Es 
existieren vier knoteninterne Sammeischienen 1301, 1302, 1303, 
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1304. Uber je eine Gruppe von Toren (1308, 1309, 1310, 1311) 
werden die Sammelschienen auf die Bussegmente Westen (1318), 
Norden (1316), Osten (1319), Sliden (1317) geschaltet. Uber die 
Tore 1307 werden die Sammelschienen mit den O-REGl/2 (vgl. DE 
196 51 075.9-53) verbunden (1314, 1315). Uber die Tore 1306 
wird das R-REG (vgl. DE 196 51 075.9-53) auf die 
Sammelschienen geschaltet. Dabei kann das niederwertige und 
hoherwertige R-REG (1312, 1313) jeweils getrennt verschaltet 
werden. Die Tore werden uber den Bus 1320 angesteuert. Dabei 
wird das benotigte Torsystem (Westen, Norden, Osten, Suden) , 
sowie die interne Sammelschiene angegeben. Durch VerUNDung 
(1325, 1326, 1327, 1328) der Richtungsangabe mit der Angabe 
der selektierten Sammelschiene wird das erf orderliche Tor 
(1321, 1322, 1323, 1324) ausgewahlt . 

Figur 14a zeigt den Aufbau einer Verbindung, dabei ubermittelt 
der Datensender (1401) dem Knoten des Datensenders (1402) das 
erste Datenpaket. 

Figur 14b Der Knoten selektiert dabei aus der Routingtabelle 

den zu rRDY rRDY ist ein Statussignal , das anzeigt, daft 

Daten am Datensender bereitstehen (vgl. DE 196 51 075.9-53) -- 
- gehorenden Eintrag. Anhand diesem Eintrag wird das nachste 
Bussegment aufgebaut und die Adresse der Routingtabelle des 
nachsten Knotens ubertragen. 

Figur 14c Der letzte Knoten (1403) , der Datenempf angerknoten, 
erhalt die Adresse fur den Eintrag innerhalb seiner 
Routingtabelle. Der Eintrag zeigt auf keinen weiteren Knoten, 
sonderen auf eine Zelle. Daher aktiviert der Knoten sofort 
seine Tore zur selektierten Zelle. 
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Figur 14d Die Daten gelangen durch das aktivierte Tor von 1403 
direkt zur Empf angerzelle 1404. 

Figur 14e Die Zelle sendet das oACK-Signal (vgl. DE 196 51 
075.9-53) als Quittierung fur die erhaltenen Daten zuriick. Im 
nachsten Buszyklus (vgl. Fig. 14e) wird der Datensender 
daraufhin das nachste Datenpaket absenden. 

Figur 14e-g Der normale Datenaustausch zwischen den Zellen 
lauft ab. 

Figur 15a Es existiert eine Datenverbindung vom Datensender 
(1501) zum Datenempfanger (1503) iiber mehrere Knoten. 
Figur 15b Der Datensender (1501) hat seine Datenubertragung 
beendet und sendet ein DISCONNECT-Signal zum ersten Knoten. 
Figur 15c Das erste Bussegment ist abgebaut und der Knoten 
reicht das DISCONNECT-Signal weiter. 
Figur 15d Der Verbindungsabbau geht weiter. 

Figur 15d Der letzte Knoten erhalt das DISCONNECT. Daraufhin 
baut der letzte Knoten gleichzeitig die Verbindung zum 
Vorgangerknoten und zum Datenempfanger ab. 
Figur 15e Das letzte Bussegment und die Verbindung zum 
Datenempfanger ist abgebaut. 

Figur I5f zeigt das ein Abbauverf ahren, bei dem die 
DISCONNECT-Leitung durch alle Knoten durchgeschleif t ist. 
Dabei wird das DISCONNECT in einem Taktzyklus propagiert; alle 
Segmente werden gleichzeitig abgerissen. 
Figur 15g entspricht Figur 15e. 

Figur 16 Zeigt die Steuerung eines Knotens . Die Anf orderungen 
(1601) zum Aufbau einer Verbindung gelangen iiber den 
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Prioritatsdekoder (1602) an die Routingtabelle (1603) . Der 
Prioritatsdekoder wahlt die Anforderung mit der hochsten 
Prioritat aus, wobei eine soeben f ehlgeschlagene Anforderung 
die niederste Prioritat zugewiesen bekommt. Die 
Prioritatslogik erhalt Ihre Anf orderungen liber Statussignale 
(z.B. der der konf igurierbaren Zellen (vgl. DE 196 51 075. 9- 
53) rRDY, oACK) oder liber die Bussegmente 1316, 1317, 1318, 
1319. Liegen Daten an den Bussegmenten an, ohne daft das Tor 
des Bussegmentes aktiviert ist, werden die Daten von der 
Prioritatslogik als Adresse der Routingtabelle interpretiert 
und als Anforderung betrachtet. Liegen Statussignale an der 
Prioritatslogik an (rRDY, oACK) , werden diese in Adressen fur 
die Routingtabelle ubertragen. Die Adressen der Routingtabelle 
selektieren einen Eintrag. Die Daten des Eintrages (1604) 
werden an eine Einheit aus UND-Gattern (1605) weitergeleitet • 
Dabei wird die Binarzahl der Busauswahl (BUS 1..0) liber einen 
2:4 Dekoder (1606) in Selektsignale ubertragen. Die UND- 
Gatter-Einheit verUNDet dabei jedes Signal mit demselben in 
einem Latch (1607) gespeicherten Signal. Das heifit daft das 
Signal GAT El der Routingtabelle mit dem Signal GAT El des 
Latches verUNDet wird, das Signal GATE2 der Routingtabelle mit 
dem Signal GATE2 des Latches und so weiter. Dabei 
reprasentieren die Signale des Latches den Zustand der 
momentan aktuellen Vernetzungsstruktur , d.h. die benutzten 
Tore und die benutzten Sammelschienen sind in das Latch 
eingetragen. Ergibt eine VerUNDung der Verbindungsanf orderung 
mit dem aktuellen Zustand einen wahren Pegel, bedeutet dies, 
daft die neue Verbindungsanf orderung Ressourcen benotigt, die 
momentan benutzt sind. Ober ein ODER-Gatter (1608) werden alle 
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UND-Gatter miteinander verkniipft. Ergibt sich am Ausgang des 
ODER-Gatters ein wahrer Pegel, wird die Verbindungsanf orderung 
zuruckgewiesen (REJECT) (1609), da die benotigten Ressourcen 
belegt sind. Aus dem REJECT-Signal wird uber einen Inverter 
(1610) das ACCEPT-Signal (1611) generiert. Die Signale 
werden an eine Zustandsmaschine (1612) , die nach dem Stand der 
Technik implementiert sein kann, weitergeleitet . Diese steuert 
danach die Annahme der Verbindung oder die Zuruckweisung . Wird 
die Verbindungsanf orderung zuruckgewiesen, meldet (1613) die 
Zustandsmaschine den REJECT an den Prioritatsdekoder und die 
Anf orderung erhalt niederste Prioritat. Bei einer Annahme der 
Anforderung, werden die neuen Zustandssignale mit den 
aktuellen Zustandssignalen nach dem Latch verODERt (1614) — 
dabei ist die ODER-Einheit ebeso aufgebaut wie die 

beschriebene UND-Einheit (1605) und in das Latch (1607) 

zuruckgeschrieben. Uber 1623 steuert die Zustandsmaschine, ob 
die ODER-Einheit (1614) oder die Maske (1616) aktiv ist. Das 
Latch wird uber 1622 von der Zustandsmaschine getriggert. Uber 
den Bus 1615 gelangt die neue Einstellung an die Tore. 

Der Abbau einer Busverbindung lauft auf ahnliche Weise. 
Allerdings findet muB bei einer Uberprtifung der Ressourcen das 
Signal REJECT auftreten, da die Busverbindung, die abgenbaut 
werden soil, existieren mull. Aufgrund des REJECTS aktiviert 
die Zustandsmaschine 1612 anstatt der ODER-Einheit 1614 die 
Maske 1616. Die Verbindungsdaten der abzubauenden Verbindung 
werden aus dem aktuellen Vernetzungszustand ausmaskiert und in 
das Latch 1607 zuruckgeschrieben. Vor dem Zuriickschreiben der 
neuen verbindungsdaten sendet die Zustandsmaschine das 
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DISCONNECT-Signal zum Abbau der Verbindung an den nachsten 
Knoten . 

Uber die Tore 1617, 1618, 1619, 1620 kann die Steuerung direkt 
auf die Sammelschienen 1301, 1302, 1303, 1304 zugreifen. Damit 
kann die Zustandsmaschine sowohl Steuersignale (DISCONNECT) 
auf die Sammelschiene iibertragen, als auch Steuersignale von 
der Sammelschiene erhalten (REJECT, ACCEPT) una auf diese 
reagieren. Ebenfalls dienen diese Tore um den Eintrag Position 
in Zieltabelle (uber 1621) auf die Sammelschiene zu 
iibertragen . 

Uber 1624 kann die Ladelogik (PLU) auf die Rout ingtabelle 
zugreif en. 

Figur 17 Zeigt ein Broadcasting eines Datensenders (1701) an 
mehrere Datenempf anger (17 02) liber eine Vielzahl von Knoten 
(1707), auf die nicht nahers eingegangen wird. Der Bus ist zur 
Verdeutlichung aufgetrennt dargestellt, namlich in die 
Quittierungsleitung (ACK) (1703) und den restlichen Bus 
(1704). ACK wird dabei negiert und an den wiederum 
invertierenden Open-Kollektor-Bustreiber geliefert. ACK wird 
uber einen PullUp-Widerstand 1705 auf H gezogen. Dabei ist die 
Schaltung so aufgebaut, daft folgende Falle eintreten: 

- Wird der entsprechende Bus nicht angesteuert, liegt an der 
Basis des Transistors (1706) L an. Dadurch belastet er den Bus 
nicht . 

- Wird der entsprechende Bus angesteuert, und das Signal nicht 
quittiert, liegt an der Basis des Transistors (1706) H an. Das 
bedeutet, daft der Bus auf L gezogen wird. Wird ein Ergebnis 
per Broadcasting an mehrere Datenempf anger verteilt, so Ziehen 
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alle Knoten, die die Ergebnisdaten noch nicht quittiert haben 
und Warte-Zyklen benotigen den Bus auf L. 

- Wird der entsprechende Bus angesteuert, und das Signal 
quittiert, liegt an der Basis des Transistors (1706) L an. Das 
bedeutet, daft der Bus nicht belastet wird. Wird ein Ergebnis 
per Broadcasting an mehrere Datenempf anger verteilt, so 
belasten alle Knoten, die die Ergebnisdaten quittiert haben 
und keine Warte-Zyklen benotigen, den Bus nicht. 
Da der Bus in seinem Grundzustand den H-Pegel, also die 
Quittierung, einnimmt, ubersteuert die Nichtquitt ierung gemaft 
Fall 2 die Quittierung, indem sie den Bus auf L zieht. Dabei 
geht der Bus erst dann in den H-Pegel, also in den 
Quittierungszustand, wenn alle an der Verbindung beteiligten 
Knoten quittieren. Es ist somit eine Wired-AND-Schaltung 
realisiert . 



Im Folgenden ist ein Implemetierungbeispiel fur einen Knoten 
dargestellt, der den folgenden Busaufbau besitzt: 



Data 


Datensignale 


ACK 


Daten- und Auf bau-Handshake 


RDY 


Datenhandshake (Daten liegen an) 


ESTABLISH 


Aufbauhandshake (das Segment wird aufgebaut) 


DISCONNECT 


Aufforderung zum Busabbau (durch einen 
Timeout) 


RECONFIG 


Aufforderung zum Busabbau (durch 
Umkonf iguration der beteiligten 
konf igurierbaren Zellen) 
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Figur 18 zeigt die Ansteuerung von der Sammelschienen aus 
Figur 13. Im Gegensatz zu der bisher beschriebenen Losung, die 
Sammelschiene in den Routingtabellen vorzugeben, ist die Logik 
in der Lage eine freie Sammelschiene selbst f estzustellen und 
zu allokieren. 

Je eine Ansteuereinheit 1801 ist einer Sammelschiene 
zugeordnet. Eine Ansteuereinheit besteht aus einem Tor 
(1801a), um wahrend des Verbindungsauf baus die 
Adressinf ormationen der Routingtabelle an die Sammelschiene 
angeschlossenen Knoten zu senden und einem Register (1801b), 
das die Ansteuerung der Sammelschiene ubernimmt . 1801 erhalt 
uber den Bus 1813 die Daten mittels einer in Figur 19 
beschriebenen Schaltung aus der Routingtabelle. Ober 1801b 
werden die Tore f reigeschaltet , die Zugriff auf die 
entsprechend zugeordnete Sammelschiene haben. Jedes Tor 
besitzt eine Freischaltesignal, dem ein Eintrag in 1801b 
zugeordnet ist. Wenn kein Eintrag gesetzt ist, ist die 
zugeordnetet Sammelschiene unbelegt und kann frei einer 
Zugriff sanforderung zugeteilt werden. Die Uberprufung wird 
durch eine ODER-Funktion (1802) uber alle Freischaltesignale 
an die Tore realisiert. Die Ergebnisse der 1802 aller 
Sammelschienen werden einem Arbiter (1803) zugefuhrt, der eine 
der freien Sammelschienen auswahlt und uber einen Adressbus 
(1804) deren 1801 anspricht. Ist keine Sammelschiene frei, 
signaiisiert 1803 dies uber 1805 der steuernden Statemachine . 
Je ein Eintrag in 1801b kennzeichnet ein der Sammelschiene 
zugeordnetes Tor. Die Position ist in jedem 1801b dieselbe. 
Das bedeutet ab Position p eines 1801b befindet sich immer das 
Freischaltesignal fur das Tor p, an Position p+1 das 
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Freischaltesignal fur Tor p+1 und an Position q das 
Freischaltesignal fur Tor q. Wird liber die Freischaltesignale 
von je einem Tor p eine ODER-Funktion (1806) ausgefiihrt, gibt 
das Resultat an, ob Tor p frei ist oder nicht. Fur jedes Tor 
existiert eine derartige Uberpruf ungsf unktion (1807 = Tor p+1, 
1808, 1809 = Tor q) . Uber eine Maske 1810 werden alle Tore, 
die fur den aktuellen Verbindungsauf bau irrelevant sind 
ausmaskiert , d.h. irrelevante Tore werden durch die Maske als 
nicht f reigeschaltet weitergeleitet . Uber eine ODER-Funktion 
(1811) wird festgestellt ob eines der Tore f reigeschaltet ist. 
Da alle irrelevanten Tore mit "nicht f reigeschaltet " markiert 
sind, wird nur der Zustand des fur den aktuellen 
Verbindungsaufbau notwendigen Tores an die State-Machine 
weitergeleitet (1812) . Ist das gewunschte Tor f reigeschaltet , 
kann es bei dem aktuellen Verbindungsaufbau nicht genutzt 
werden, da ansonsten eine Kollision eintreten wurde . Der 
Verbindungsaufbau wird unterbrochen und entweder 
zuriickgewiesen oder zu einem spateren Zeitpunkt erneut 
versucht . 

In Figur 19 ist der Arbiter zur Auswahl des aktiven Busses und 
die Routingtabelle dargestellt. Jeder an einen Knoten 
angeschlqssene Bus (2004, 2005, 2006) sendet seine 
Zugrif f sanf orderung uber ein Signal (1901) an einen Arbiter 
(1902), der eine der Zugrif f sanf orderungen auswahlt. Uber 
einen Dekoder (1903) wird der Multiplexer (1904) so 
angesteuert, daft entweder die Nummer des ausgewahlten 
Zugriffes (bei direkten Zugriff durch eine konf igurierbare 
Zelle) (1905) oder die Lookup-Addresse des ausgewahlten 
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Zugriffes an die Routingtabelle 1906 ubertragen wird. 1906 
gibt die, dem Wert von 1905 zugeordneten, Daten aus . Die 
Lookup-Addresse fur den nachsten Knotens wird direkt uber 1813 
an 1801a ubertragen. Die Adresse des nachsten Knotens wird 
dezimal auskodiert (1907) uber einen Mischer (1908), der fur 
gewohnlich aus ODER-Gattern ausgestaltet ist, mittels des 
Busses 1813 an 1801b ubertragen. Ist der Bus zum nachsten 
Knoten aufgebaut, wird die Freischaltung des Tores zum 
vorhergehenden Knoten ermoglicht, indem die uber den 
Dezimaldekoder 1909 auskodierte Adresse des vorhergehenden 
Knotens im Mischer 1908 auf den Bus 1813 zugeschaltet wird und 
zu 1801b ubertragen wird. 

Figur 20 zeigt die Sammelschienen (2001, 2002, 2003) zur 
Aufschaltung der anliegenden Busse (2004, 2005, 2006) . Ober 
die Multiplexer/Demultiplexer (2007) werden die Busse gemafi 
der Ansteuerung durch 1801b auf die Sammelschienen geschaltet, 
dabei werden einem Multiplexer p die Ausgangssignale p aller 
1801b zugefuhrt, einem Multiplexer p+1 die Ausgangssignale p+1 
aller 1801b, etc. Die einzelnen Signale reprasentieren 
anliegen.de Sammelschienen, da jede Sammelschienensteuerung 
genau eines (p) aus einer Vielzahl von Signalen (p x , p x +I , . , , q x ) 
ansteuert. Ist ein zu einer Sammelschienensteuerung gehorendes 
Signal gesetzt, wird die entsprechende Sammelschiene durch 
einen 2007 auf geschaltet . 

Die Timeout-Generatoren (2008) steuern den Abbau des 
jeweiligen Segmentes und den auf geschalteten Bussen. Die 
Timeout-Generatoren werden direkt von der Routingtabelle 



37 



WO 98/35294 



r 

PCT/DE98/00456 



(1906) konf iguriert . Die Verbindung ist der Einfachheit halber 
in den Zeichnungen nicht dargestellt. 

Die einer jeweiligen Sammelschiene zugeordneten 1801a werden 
auf diese Sairanelschiene auf geschaltet . 

In Figur 21 wird ein Bussegment (2105) liber einen Knoten 
(2101) an mehrere Knoten (2102, 2103, 2104) gebroadcastet . Das 
RDY-Handshake wird, ebenso wie die Daten direkt an jeden 
Empf anger gesendet. Uber die Masken (2105, 2106) werden die 
rucklaufigen ACK-Handshakes auf das ODER-Gatter (2107) und das 
UND-Gatter (2108) geschaltet. Uber die Masken wird dabei 
ausgewahlt, welches ACK signifikant ist, und ob ein ACK durch 
eine boolsche UND-Funktion oder eine ODER-Funktion 
weitergeleitet wird. Beide Funktionen werden uber ein ODER- 
Gatter (2109) zusammengefalit. Ist ein ACK irrelevant, so gibt 
die Maske 2105 eine logische 0 (L-Pegel) weiter, wahrend die 
Maske 2106 eine logische 1 (H-Pegel) weitergibt. Die Masken 
2105 und 2106 werden getrennt von der Routingtabelle gesetzt. 
Die Verbindung ist der Einfachheit halber in den Zeichnungen 
nicht dargestellt. 

In Figur 22 ist die Statemachine der beschriebenen Schaitung 
dargestellt . 

Der Grundzustand ist "IDLE", den die Statemachine erst 
verlaflt, wenn ein "request" (Zugriff) auftrat UND eine 
Sammelschiene UND das selektierte Tor frei sind. Dabei 
quittiert die Statemachine der vorhergehenden Statemachine den 
Busaufbau durch senden eines ACK-Handshakes. Die Statemachine 
geht in den SEND-Zustand, wahrend dessen die Daten der 
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Routingtabelle (uber 1801a) an die nachfolgende Routingtabelle 
gesendet werden. Diesen Zustand verlafit die Statemachine erst 
beim Eintreffen eines ACK-Handshakes der nachf olgenden 
Routingtabelle ODER beim Eintreffen eines "disconnect"- 
Signales auf dem Bus, z.B. durch einen Timeout. Bei einem 
"disconnect" geht die Statemachine in den DISCONNECT-Zustand, 
um den Bus abzubauen (dieser Zustand ist nicht notwendig, in 
der Implementierung wird direkt nach IDLE zuriickgesprungen, 
dient aber in diesem Beispiel der besseren Obersicht) . Bei 
Eintreffen eines ACK-Handshakes wird in den IDLE-Zustand 
zuriickgesprungen, dabei wird uber 1909/1908 das Tor der 
vorhergehenden Routingtabelle in 1801b f reigeschaltet . 
Um die Leistung der Routingtabelle zu erhohen kann auf das 
warten auf ein ACK-Handshake wahrend des SEND-Zustandes 
verzichtet werden. Dazu mussen wahrend SEND die zu sendenden 
Zugrif f sdaten an die nachfolgende Routingtabelle in 1801a 
gespeichert werden, d-h. 1801a ist ein Register; gleichzeitig 
mufi wahrend SEND die Information uber die vorhergehende 
Routingtabelle in ein zusatzliches 1801b geschrieben werden. 
Das Eintreffen des ACK-Handshakes der nachf olgenden 
Routingtabelle, bewirkt in unabhangig aufgebauter Logik das 
Abschalten von 1801a und das Umschalten von dem erste 1801b 
auf das Zweite, indem die Verschaltung des Tors der 
vorhergehenden Routingtabelle gespeichert ist. 

Die folgenden Figuren beschreiben ein Implementationsbeispiel 
nach dem "erweiterten" Routingverf ahren, der Bus sieht wie 
folgt aus: 



39 



WO 98/35294 



PCT/DE98/00456 



Data 


Datensignale 


ACK 


Daten- und Auf bau-Handshake 


RDY 


Datenhandshake (Daten lxegen an) 


DISCONNECT 


Aufforderung zum Busabbau (durch einen Timeout) 


RECONFIG 


Aufforderung zum Busabbau (durch Umkonf iguration 
der beteiligten konf igurierbaren Zellen) 


X/ Y 


X/Y-Raumkoordinaten 


LUT 


Lookup-Adresse fur die Routingtabelle 


ADR-MODE 


Gibt an ob die X/Y-Raumkoodinaten oder die 
Lookup-Adresse verwendet werden soli. 1st X=0 
UND Y=0 wird automatisch die Lookup-Adresse 
verwendet . 



Figur 23 zeigt einen Knoten mit den Schaltelementen 
1,2,3,4,5,6, sowie den Bussen Bl, B2, B3, B4. 

Figur 23a) . Die Zeichnung ist zur besseren Darstellbarkeit als 
ein Ein-Leitungssystem ausgestaltet . Tatsachlich handelt es 
sich urn ein Bussystem. Dazu sind alle Figuren um die Menge der 
Busleitungen zu duplizieren. Die Schaltelemente sind im 
einfachsten Fall aus einem Transistor (2301) aufgebaut- 
Figur 23b) Um Daten zwischenspeichern zu konnen, wird das 
Schaltelement um ein Register (2302) erweitert. Ober die 
Transistoren Tl, T2, T3, T4 werden die bidirektionalen Busse 
3n und Bm so auf das Register geschaltet, daft entweder der 
Ubergang Bm -> Bn oder der Ubergang Bn -> Bm gespeichert wird. 
Uber T5 wird alternativ ein bidirektionaler ungespeicherter 
Datentransf er ermoglicht. Uber die Steuersignale SI, S2, S3, 
S4 wird der Modus des Schaltelementes wie folgt eingestellt: 

40 



WO 98/35294 



PCT/DE98/00456 



SI 


Bm -> Bn (unidirektional, gespeichert) 


S2 


Bm <-> Bn (bidirektional , nicht gespeichert) 


S3 


Bn <-> Bm (bidirektional, nicht gespeichert) 


S4 


Bn -> Bm (unidirektional, gespeichert) 



Figur 23c) Um eine bessere Signalqualitat zu erhalten, werden 
Eingangsschmittrigger und Ausgangstreiber (2303) eingesetzt. 
Die Treiber (2303) sind so ausgestaltet , daft iiber ein 
Steuersignal pegelabhangig- entweder der Ausgangs oder der 
Eingancstreiber f reigeschaltet wird. Die Bidirektionalitat 
geht verioren, es sind ausschiefilich unidirekt ionale 
Schaltvorgange realisierbar : 

S4 wird der Modus des Schaltelementes wie folgt eingestellt: 



SI 


Bm -> Bn (unidirektional, gespeichert) 


S2 


Bm -> Bn (unidirektional, nicht gespeichert) 


S3 


Bn -> Bm (unidirektional, nicht gespeichert) 


S4 


Bn -> Bm (unidirektional, gespeichert) 



Figur 23d) Die Ein- und Ausgange verlaufen auf 

unterschiedlichen Leitungen (Bmi, Brno, Bni, Bno) zur besseren 
Implementierbarkeit in Chips. Die Treiber (2304) sind 
unidirektional ausgestaltet. Die Ansteuerung der Treiber kann 
entf alien. 
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SI 


Bmi 


-> 


Bno 


(unidirektional, 


gespeichert ) 


S2 


Bmi 


-> 


Bno 


(unidirektional, 


nicht gespeichert) 


S3 


Bni 


-> 


Brno 


(unidirektional, 


nicht gespeichert) 


S4 


Bni 


-> 


Brno 


(unidirektional, 


gespeichert) 



Figur 24 zeigt einen Knoten ahnlich dem Knoten aus Figur 23. 
Der Vorteil des Knotens liegt in seiner besseren 
Implementierbarkeit und Verwaltung der Register. Die Zeichnung 
ist zur besseren Darstellbarkeit als ein Ein-Leitungssystern 
ausgescaltet . Tatsachlich handelt es sich urn ein Bussystem. 
Dazu sind alle Figuren um die Menge der Busleitungen zu 
duplizieren. Die Register und Treiber (A, B, C, D) sind den 
Schaltelementen (1, 2, 3, 4, 5, 6) vorgeordnet . Die 
Schaltelemente reduzieren sich auf die in Figur 24a gezeigte 
Kreuzschaltung. Mittels der Transistoren T6, T7 werden die 
Eingange (Imi, Ini) jeweils selektiv mittels der 
Steuerleitungen S5, S6 auf die Ausgange (Imo, Ino) geschaltet. 
Die Figuren 24b-d zeigen verschiedene Ausgestaltungsarten der 
Register und Treiber (A, B, C, D) . 

In Figur 24b wird ein bidirektionaler Bus uber T8 entweder als 
Eingang zum Regsiter 2401 geschaltet, oder uber T9 aus Ausgang 
geschaltet, wobei der knoteninterne Bus Imo die Signalquelle 
darstellt. T8 und T9 werden uber die Steuerleitung S7 
angesteuert. Mittels des Transistorpaares T10/T11, das uber S8 
angesteuert wird, kann ein Register-Bypass geschaltet werden 
um den quasi-permanenten Modus zu ermoglichen. Der Ausgang des 
Registers geht auf den knoteninternen Bus Imi. Die Vernetzung 
der Imi und Imo erfolgt uber die Schaltelemente aus Figur 24a. 
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In Figur 24c wir anstatt des Transistorpaares T8/T9 eine 
Treiberstufe (2402) zur Verbesserung der Signalqualitat zurn 
Bus geschaltet. 

In Figur 24d ist der externe Bus zur besseren 

Implementierbarkeit in Chips unidirektional ausgestaltet . Die 
Treiber 2403 sind unidirektional, das Steuersignal S7 
entf allt . 

Figur 25 schlagt eine mogliche Synchronisationsschaltung fur 
Fig. 24 vor. Die Register 2401 zur Datenspeicherung sind in 

2501 dargestellt. Das Register 2502 dient der Speicherung 
eines RDY-Handshakesignales, also der Information, daft sich 
gultige Datenen auf dem Bus, bzw. in 2501 befindet. Befindet 
sich keine gultigen Daten in 2501, ist der Ausgang Q von 2502 
logisch 0. Treffen gultige Daten ein (RDY ist aktiv und 
logisch 1), wird uber das UND-Gatter 2503 ein 
Freischaltesignal (EN) fur die Register 2501 und 2502 
generiert, die Daten und das RDY werden mit der steigenden 
Taktflanke gespeichert. Der Eingang von 2503 fur Q (von 2502) 
ist invertierend! Treffen erneut Daten ein, ist der Ausgang 
(Q) von 2502 logisch 1. Das UND-Gatter liefert eine logische 0 
und die Register werden uber EN nicht f reigeschaltet . Werden 
die Daten uber den Bus weitergeleitet , wird das 
Aktivierungssignal des Ausgangstreibers (OE) als Clear fur 

2502 verwendet; Q von 2502 wird logisch 0 und neue Daten 
konnen mit dem nachsten Taktzyklus gespeichert werden. Die 
Leitung Din und Dout ist fett eingezeichnet , da es sich hier 
urn ein Bussystem handelt. Ebenso ist 2501 fett gezeichnet, da 
das Register der Breite des Busses entspricht. 
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Es ist moglich die Register als Latches aufzubauen und an die 
Pegei des Taktes (CLK) oder Handshakes (RDY) zu koppeln. Die 
Schaltung verhalt sich dadurch allerdings asynchron, was zu 
erheblichen Implementierungsproblemen fuhrt und dadurch einem 
nicht unerheblichem Zusatzaufwand unterliegt. 

Figur 26 zeigt die Teststrategie urn f estzustellen, ob eine 
Verbindung aufgebaut werden kann, d.h. das Netz frei ist. Die 
Statusinf ormationen der Schaltelemente 1,2,3,4,5,6, die 
Auskunft geben ob ein Schaltelement verschaltet oder frei ist, 
werden in einer Matrix 2603 angeordnet. Dabei bilden die 90 °- 
Schaineiemente 3,4,5,6 die Ecken, die 180 °-Schaltelemente 1 
und 2 die Mittelstucke und kommen doppelt vor. Um ein 
Schaltelement kollisionsf rei zu benutzen mufi die gesamte Kante 
in welcher sich das Schaltelement befindet frei sein. 
Beispielsweise ist es moglich 1+2, 6+4, 3+5 zu benutzen. 
Unmoglich dagegen ist beispielsweise 6+2, 6+1, 2+5, 2+4, 2+3, 
etc. 

Es mull also sichergestellt und getestet werden, dafi jede Kante 
nur einmal belegt ist. Die Daten hierzu liefert ein Register 
2 602, in dem die aktuelle Verschaltung des Knoten gespeichert 
ist uber den Eingang r; sowie die Routingtabelle 2601, die die 
Daten des gewunschten neuen Busses uber den Eingang t an die 
Matrix weiterleitet . 

Die Testschaltung ist in Figur 26a dargestellt. Je eine Reihe 
(2605, 2606, 2607, 2608) wir liber ein ODER-Gatter (2609, 2610, 
2611, 2612) auf die Existenz einer Verschaltung uberpruft. 
Existiert ein verschaltetes Element in der Reihe, liefert das 
jeweilige ODER-Gatter eine logische 1. Das Ergebnis der 
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jeweiligen Reihe wird mittels jeweils eines UND-Gatters mit je 
einer sich in der Reihe befindenden, neu auf zubauenden 
Verschaltung verkniipft. 1st die Reihe bereits belegt UND eine 
weitere Verschaltung in der Reihe wird angefordert, liefert 
das jeweilige UND-Gatter eine logische 1. Die Ausgange aller 
UND-Gatter werden verODERt (2613) . Das Ergebnis des Tests 
liefert somit an 2604 eine logische 0, wenn die angeforderte 
Vernetzung giiltig ist und eine logische 1, wenn eine Kollision 
vorliegt . 

Die Schaltung in Figur 26 ist lediglich in der Lage eine 
Anforderung pro Zeiteinheit zu verarbeiten. Eine zeitliche 
Optimierung ist in Figur 27 dargestellt. Uber 2701 gelangen 
die Zugrif f sanf orderungen von den Bussen an die Schaltung. Die 
Routingtabelle (2702) ist nicht aus einem ublichen Speicher, 
sondern aus einer Mehrzahl von einzelnen Registern (2711) 
aufgebaut. Dadurch konnen uber die Multiplexer 27 03 die Daten 
samtlicher Zugrif f sanf orderungen gleichzeitig aus der 
Routingtabelle ausgelesen werden. Die Daten je einer 
Zugrif f sanf orderung werden an je eine Matrix (2704) gemafi 
Figur 26 geleitet, das die Vergleichsdaten aus dem Register 
mit der aktuellen Verschaltung der Knoten (2705) erhalt. Die 
Schaltung 2706 besteht aus einem ODER-Gatter, das das 
Vorhandensein einer gultigen Anfrage an die Matrix 2704 
feststellt. Das Ergebnis von 2704 wird uber einen Inverter mit 
dem Ausgang des ODER-Gatters verUNDet. Als Ergebnis wird bei 
einem bestehenden und gultigen Zugrif f eine logische 1, 
ansonsten eine logische 0 geliefert. Jede Matrix besitzt je 
eine Schaltung 2706. Deren Ergebnisse werden auf einen Arbiter 
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2707 geschaltet, der einen der gultigen Zugriffe auswahlt. Der 
Multiplexer 2708 wird so geschaltet, dafi die Daten des 
gultigen Zugriffes auf den Mischer 2709 gelangen, der den 
gultigen neuen Zugriff mit der bestehenden Verbindung 
verkniipft und an das Register 2705 zur Speicherung 
weiterleitet . 

Diese Schaltung ist in der Lage aus einem Menge von 4 
Zugriff en genau einen Gultigen auszuwahlen. Durch Anderung der 
Anzahl der Multiplexer (2703), Matrizen (2704), der Arbiter- 
und Multiplexerbreite (2707, 2708) sowie der dazugehorenden 
Logiken, kann ein gultiger Zugriff aus einer beliebig 
einstellbaren Menge von Anfragen bearbeitet werden. 

Oftmals ist es erforderlich mehr als einen gultigen Zugriff 
aus einer Menge von Zugriff en auszuwahlen. Dazu dienen die 
Leitungen 2801, 2805, 2802 und 2810, die zu der 

Zusatzschaltung Figur 28 fiihren und eine gleichzeitige Auswahl 
von 2 Zugriff en ermoglichen . Wird 2810 verdrahtet, entfallt 
die Leitung 2710. Nach dem irn Folgenden vorgestellten Prinzip 
kann durch Kaskadierung eine beliebige Menge von Zugriffen 
gleichzeitig ausgewahlt werden. 

Uber 2801 gelangt die Information, welcher Zugriff als 
"giiltig" ausgewahlt wurde, an den Dekoder 2803. Die 
Information wird so auskodiert, daft uber die drei Multiplexer 
2804 nur die Zugriff sdaten der nicht ausgewahlten Zugriff an 
die Matrizen geleitet werden. Durch den Wegfall des bereits 
ausgewahlten Zugriffes verringert sich die Zahl der Matrizen 
um eins. 



46 



WO 98/35294 PCT/DE98/00456 



Der Dekoder arbeitet wie in der Tabelle angegeben: 



Dekoder 
(2802) 


MUX1 


MUX2 


MUX3 


a 


b 


c 


d 


b 


a 


c 


d 


c 


a 


b 


d 


d 


a 


b 


c 



Die Tabelle gibt in der Spalte "Dekoder" den iiber 2802 
selektierten "gultige" Bus an. In den Spalten MUX1-MUX3 wird 
angegeben, welchen Bus der jeweilige Multiplexer, abhangig von 
dem Wert 2802, selektiert. 

Die Matrizeh (2811), die Logik (2806) und der Arbiter (2807) 
arbeiten wie aus Figur 27 bekannt. Ober den Multiplexer 2808 
werden die Daten des vom Arbiter ausgewahlten Zugriffes an dem 
Mischer 2809 geleitet. Der fiigt ahnlich dem Mischer 2709 den 
Ausgangsdaten von 2709 die Daten des von der Logik von Figur 
28 ausgewahlten Zugriffes zu und leitet die generierten 
Zugriffsdaten iiber 2810 an das Register 2705. Die 
Eingangsdaten des Multiplexers 2808 mussen aufgrund der 
Verschaltung in den Multiplexer 2804 von deren Ausgangen 
abgegriffen werden. 

Die Schaltung gemafi Fig. 28 ist in die Tiefe nach dem 
beschriebenen Prinzip weiter kaskadierbar, wobei sich die Zahl 
der Matrizen weiter urn jeweils eins pro Kaskade verringert. 

Figur 29 beschreibt ein Register gemafi 2602 bzw. 2705. Die 
Ausgange der Mischer 2709 bzw. 2809 werden iiber 2901 als 
Eingangsdaten an das Register gefuhrt. Je eine Registerbank 
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2902a/b verwaltet einen der Busse (Bl,B2,..Bm) des Knotens. Im 
Teil a einer Bank ist die Ansteuerung des Knotens gespeichert • 
In Teil b ist das Timeout der Busverbindung definiert. Teil b 
besteht aus einem ladbaren Zahler, dessen enable und reload 
liber den Multiplexer 2 903, einstellbar durch Teil a, gewahlt 
wird. 



Timeout- Prinzip 


Wirkung 


BUS-ACK 


Die Datentransf ers werden gezahlt. 
(Bus in use / Paketgrofie) 


! BUS-ACK 
(invertiert ) 


Die Takte ohne Datentransf er werden 
gezahlt. (Bus NOT not use / Timeout) 


en 


Jeder Takt wird gezahlt / Takt-Zyklen 




Kein Timeout / permanent 



Die Signale reload und enable des Zahlers werden bie folgt 
generiert : 



Timeout- Prinzip 


reload (rid) 


enable (en) 


BUS-ACK 


nie 


bei Datentransf er 


1 BUS-ACK 
(invertiert) 


bei Datentransf er 


ohne Datentransf er 


en 


nie 


standig 




nie 


nie 



Dabei ist das fur einen Reload, also das Neuladen des Zahlers, 
benotigte Register, das den ursprunglich gesetzien Zahlerstand 
enthalt in 2902b enthalten. 2904 testet auf den Zahlerstand 0 
urn den Timeout f est zustellen . 2904 ist in der Figur nur des 
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Verstandnis halber aufgezeigt; in der Implementierung wird das 
Ubertragssignal (Ripple-Carry) des Zahlers verwendet. Der 
Obertrag loscht den Inhalt von 2902a, welches danach die 
Zustandsinf ormation "Bus-frei" weitergibt und somit den Bus 
abreifit. Aus dem Obertrag wird als Signal BUS- DISCONNECT auf 
den Bus geschaltet und zum AbriB der restlichen Bussegment 
verwendet. BUS-RECONF wird gemafJ DE 197 04 728.9 mit den Daten 
mitgefuhrt und bewirkt bei Auftreten ebenfalls den Abrili des 
Busses. Ober das ODER-Gatter 2905 werden beide Signale 2902 
zugefuhrt und bewirken das Loschen des Registers und Zahlers. 
Der Timeout wird deaktiviert f indem gemafi den vorher 
aufgefuhrten Tabellen das enable-Signal deaktiviert ist und 
der Zahler mit einem Wert grofier null geladen wird. 
Die Daten in dem Register sind busorientiert , nicht 
schaltelementorientiert . Diese Daten gelangen uber 2906 an die 
Mischer 2709 und 2809. Jedes Steuersignal kommt m-fach (Anzahl 
der Busse) vor und wird in der Notation S i#m bezeichnet, wobei 
m fur den Bus und i fur die Nummer des Schaltelements steht. 
Bevor die Daten an eine Matrix gemafi Figur 2 6 oder an einen 
Knoten gemafi den Figuren 23/24 gefuhrt werden mussen diese in 
der Art abgebildet werden, dali lediglich eine Folge T± 
existiert. Die Abbildungsvorschrif t lautet dabei Ti = (S if i u 

Si, 2 v S±,3 o ... ^ S i/In ) / mit anderen Worten alle S± tX bis Si, m 
werden verODERt. 2907 ubernimmt diese Funktion und fuhrt T 
uber 2908 den Matrizen und Schaltelementen zu. 

Figur 30 zeigt ein Beispiel fur zwei Busverbindungen. 

Konf igurierbaren Elementen oder Gruppen von konf igurierbaren 
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Elementen (3001) ist ein Knoten 3002 zugeordnet . Der Knoten 
3003 ubertragt Daten zum Knoten 3004. Der Verbindungsauf bau 
ist statisch. Der Knoten 3005 ubertragt die Daten dynamisch an 
den Zielknoten 3008. Dabei sind die Segmente 3006 und 3007 
belegt, sodafi sich die Laufrichtung jeweils andert. Die X/Y- 
Raumkoordinaten sind in den jeweilig durchlauf enen Knoten 
angegeben. Dabei werden die Koordinaten je nach Laufrichtung 
gleichbehalten, urn eins erhoht oder verringert. Anhand des 
Zahlenwertes der Koordinaten kann die Laufrichtung und das 
Ziel ausgemacht werden. Dabei wird aus der Position (A, B, C, 
D) des eingehenden Busses am Knoten und dem Vorzeichen der 
(X/Y)- Bewegung die Abweichung der Bewegungsrichtung 
berechnet. Dabei werden Himmelsrichtungen zur Bezeichnung 
verwendet, wobei y die Nord-Sud Achse und x die Ost-Wes:: Achse 
bildet: 



Laurrichtung 


Bewegung in 
Himmelsrichtung 


y = 0 


x > 0 => 0 
x < 0 W 


y > 0 


N 


y < 0 


S 


x = 0 * 


y > 0 => N 
y < 0 => S 


x > 0 


0 


x < 0 


W 
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Anhand der Laufrichtung und der Himmelrichtung des eingehenden 
Busses kann berechnet werden, welches der Schaltelemente 
(1,2,3,4,5,6) angesprochen wird. Beide oben genannten 
Berechnungen sind trivial, so daft die notwendige 
Berechnungseinheit (XY2ADR) beispielsweise durch Lookup- 
Tabellen ausgestaltet werden kann. Daher wird auf die 
Berechnung nicht weiters eingegangen, sondern auf die oben 
gezeigte Tabelle verwiesen. 

Die Adressierung in diesem Beispiel ist relativ. 

Figur 21 zeigt dasselbe Beispiel mit absoluten Koordinaten. Im 
Gegensatz zu Figur 30 werden die Koordinaten in den Knoten 
nicht berechnet, sondern mit den Koordinaten der Knoten gemali 
dem ubergeordneten Koordinatensystem 3101 verglichen. Anhand 
der Vergleiche, grower (>) , kleiner (<) und gleich ( = ) wird 
der Verbindungsaufbau gesteuert. Sind beide Koodinaten (X und 
Y) gleich den Koordinaten des Knotens, ist das Ziel erreicht, 
ist eine Koordinate gleich der Koordinate des Knotens, ist die 
Zielachse der Koordinate erreicht. 

Die in den Figuren 30 und 31 aufgefuhrten Beispiele lassen 
keine Abweichung von der optimalen Richtung zu. Ware 
beispielsweise das Segment 3009 in Figur 30 belegt, konnten 
die Daten nicht weiter transferiert werden. Es ist moglich im 
Besetzt-Fall eine Abweichung von der vorgegebenen Richtung 
zuzulassen. Dann konnte die Verbindung liber 3010 aufgebaut 
werden. Allerdings muft der Raum fur eine mogliche Abweichung 
begrenzt werden, urn keine unsinnigen Routingversuche zu 
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erhalten. Eine sinnvolle Schranke fur Abweichungen von der 
vorgegebenen Richtung liegt bei bis +/-2. 

Figur 32a und 32b zeigen die notwendige Peripherie urn einen 
Knoten 3201 , urn die Raumkoordinaten auszuwerten, bzw. zu 
modif izieren . 

Figur 32a modifiziert relative Koordinaten entsprechend ihrer 
Lauf richtung- In positiver Richtung wird subtrahiert (3203), 
in negativer Richtung addiert (3202). Die Vergleicher (3204) 
stellen priifen, ob eine Koordiante 0 erreicht hat. 
Figur 32b vergieicht absolute Koordinaten mit den Koordinaten 
des Knotens, mittels der Vergleicher 3205. 
Um eine Abweichung von der vorgegebenen Richtung zu 
ermoglichen, werden die Vergleicher 3205 und 3204 so 
erweitert, daJi sie die Information, ob sich eine Koordinate im 
Abweichungbereich befindet uberprufen und weitergeben 
<-Abweichung<Koordinate<Abweichung) . Anhand dieser Information 
kann die Berechnungseinheit (XY2ADR) bei einer Kollision der 
vorgegebenen Richtung, die Bewegungsrichtung innerhalb der 
Grenzen der zulassigen Abweichung modifizieren und eine 
Abweichung zulassen oder verhindern. Auch diese Berechnung ist 
trivial und kann ggf . durch Erweiterung der Lookup-Tabellen 
durchgefuhrt werden, in der nachf olgenden Tabelle ist die 
maximal zulassige Abweichung durch A angegeben: 
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Lauf richtung 


Bewegung in 
Hinune lsrirht nnn 

* i xi mn ^ > t j_ ^ hi, 1 1 \ j 


y-A = 0 


X+A > U => U 
x-A < 0 => W 


y+A > 0 


N 


y-A < 0 


S 


x-A = 0 


y+A > 0 => N 
y-A < 0 S 


x+A > 0 


0 


x-A < 0 


W 



Die Umgebung von x und y wird dabei unscharf, d.h. es ist 
mdglich, daft Bewegungen in entgegengeset zte Himmelsrichtungen 
zulassig werden, da gleichzeitig k-A<0 UND k+A>0 gelten kann. 
Dies kann wenn gewunscht eingegengt' werden, indem keine 
Lauf richtung entgegen des Vorzeichens von k zugelassen wird. 
Ist k = 0 sind alle Lauf richtungen zugelassen. 

Figur 33 zeigt das Verhalten eines segmentierten Busses. Der 
Aufbau der Zeichnung entspricht dem bereits bekannten. Ein 
Senderknoten Sa sendet Daten an den Empf anger konten Ea, ein 
weiterer Senderknoten Sb sendet an Eb und ein Letzter Sc an 
Ec, der auch der Empf angerknoten Eb ist. Dabei treten an den 
Segmenten 3301 und 3302 Kollisionen auf. Zur optimalen 
Ausnutzung des Busses (abgesehen davon, daft prinzipiell eine 
andere Wegfuhrung moglich ware) werden alle Busse quasi- 
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permanent aufgebaut; mit Ausnahme der Segmente 3301 und 3302. 
Diese Segmente arbeiten in dem Modus "Registered" und 
arbitrieren gemafi dem eingestellten Timeout je einen der 
anstehenden Busse. Uber den jeweiligen Timeout kann die 
Prioritat der einzelnen Busse festgelegt werden. Ein 
relevanter Bus erhalt grofie "Timout-Rechte" , also lange 
Zyklen, wahrend einem irrelevanten Bus kurze Zyklen zur 
Verfligung stehen. 

Die bisherigen Beschreibungen der Knoten in den Figuren 23-27 
zeigen der Vereinf achung halber nur die Vernetzung in die vier 
Himmelsrichtungen. Tatsachlich mussen in einem Knoten jedoch 
zusatzlich jeweils eine konf igurierbare Zelle oder eine Gruppe 
von konf igurierbaren Zellen auf geschaltet werden. Die hierfiir 
notwendigen Erweiterungen sind in Figur 34 dargestellt. Die 
Kennzeichnungen der Knoten entsprechen in Figur 34a der Figur 
23 und in Figur 34b der Figur 24; der AnschlufJ der 
konf igurierbaren Elemente ist mit Z gekennzeichnet . Die Matrix 
2603 ist gemaft Figur 34c zu 3401 zu andern. Die Anderung der 
Verschaltung erfolgt entsprechend Fig. 26. 

Die vorgestellten Beispiele sind der Verstandlichkeit halber 
auf 2-dimensionale Systeme ausgelegt. Auf Grundlage der 
vorgestellten Verfahren sind entsprechend komplexe beliebig 
mehrdimensionale Systeme baubar. 
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Begrif f sdef inition 

Address -Lookup Die Adresse wird nicht berechnet, sondern 

durch "nachsehen" in einem Speicher generiert. 

ALU Arithmetisch logische Einheit. Grundeinheit zum 

Verarbeiten von Daten. Die Einheit kann arithmet ische 
Operationen wie Addition, Subtraktion, unter Umstanden auch 
Multiplikation, Division, Reihenentwicklungen usw. durch\- 
fuhren. Dabei kann die Einheit als ganzzahlige (integer) 
Einheit oder als Flielikomma- ( floating-point ) -Einheit gestaltet 
sein. Ebenfalls kann die Einheit logische Operationen, wie 
UND, ODER, sowie Vergleiche durchfuhren. 

Aufbauphase Zyklus wahrend dessen ein Bussegment aufgebaut 
wird. 

Arbiter Einheit urn Rechte zwischen Signalen zu verteiien. 

bidirektional Datenubertragung in beide Richtungen 

(Quelle/Ziell <-> Quelle/Ziel2 ) 

Broadcast Senden von Daten einer PAE an mehrere oder alle 

Datenempf anger . 

Busanf orderung Die Anforderung eine Busverbindung zum 

Datentransfer aufzubauen. (Auch Verbindungsanf orderung) 



55 



WO 98/35294 



PCT/DE98/00456 



Bussegment Abschnitt eines Bussystems zwischen zwei 

Knoten 

Buszustande Art und Weise wie ein Bus arbeitet. Es wird 
zwischen zwei Haupt zustanden unterschieden : 

Quasi -permanent: Der Bus verhalt sich wie eine durchgehende 
Leitung. Der Bus ist nur von einem Datenpaket verwendbar (bis 
zu seinem Abriss) . 

Registered: Zwischen jedem Segment ist ein Register 
eingeschleif t , das die Daten um einen Taktzyklus verzogert. 
Bei jedem Taktzyklus (abhangig von Timeout) kann ein anderes 
Datenpaket arbitriert werden. 

Eine Mischung der beiden Zustande ergibt den Zustand 
Segmentiert, der beide Vorteile miteinander verbindet . 

Datenempf anger Die Einheit(en), die Ergebnisse der PAE 
weiterverarbeitet/-arbeiten} 

Datensender Die Einheit (en) , die Daten fur die PAE al 

Operanden zur Verfugung stellt /stellen } 

Datentyp ' Art der Daten: Zeichen, Zahlen, 

Flieflkommazahlen, Signale (boolean), etc. 

Dezimaldekoder Wandelt ein binares Signal in ein 

Dezimales um. 
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DFP Datenfluflprozessor nach Patent/Of fenlegung DE 44 16 

881 

DISCONNECT Von Timeout-Zahlern/Generatoren generiertes 

Signal zum Abriss eines Busses. Wird an alle Knoten eines 
Busses gefuhrt. 

DPGA Dynamisch konf igurierbare FPGAs . Stand der Technik 

EALU Erweiterte arithmetisch logische Einheit . ALU, die 

um Sonderfunktionen, die zum Betrieb einer 

Datenverarbeitungseinrichtung gemaft DE 441 16 881 Al benotigt 
werden oder sinnvoll sind erweitert wurde . Dies sind ins 
besondere Zahler. } 

Elemente Sammelbegrif f fur alle Arten von in sich 
abgeschlossenen Einheiten, welche als Stuck in einem 
elektronischen Baustein zum Einsatz kommen konnen. Elemente 
sind also: 

- Konf igurierbare Zellen aller Art 

- Cluster 

- RAM-Blocke 

- Logik 

- Rechenwerke 

- Register 

- Multiplexer 

- I/O Pins eines Chips 
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Enable Freischalten eines Registers oder Zahlers. 

FPGA Programmierbarer Logikbaustein . Stand der Technik. 

Gatter Gruppe von Transistoren, die eine logische 
Grundfunktion durchfuhren. Grundf unktionen sind z.B. NAND, 
NOR, Transmission-Gates . 

Geschwindigkeitsoptimiert Ein Bussystem, das meist quasi- 

permanent aufgebaut ist, eine hohe Prioritat besitzt und nicht 
von anderen Zugriffen beeinflufit wird. 

H-Pegel Logisch 1 Pegel, abhangig von der verwendeten 
Technologie 

Knoten Element das mehrere Bussegmente miteinander 
verbindet und den Verbindungsaufbau aktiv steuert, wahrend des 
Datentransf ers jedoch passiv ist. 

konf igurierbares Element Ein konf igurierbares Element stellt 
eine Einheit eines Logik-Bausteines dar, welche durch ein 
Konf igurationswort fur eine spezielle Funktion eingesteilt 
werden kann. Konf igurierbare Elemente sind somit, alle Art en 
von RAM-Zellen, Multiplexer, Arithmetische logische Einheiten, 
Register und alle Arten von interner und externer 
Vernet zungsbeschreibung etc . 

konf igurierbare Zelle Siehe Logikzellen 
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Konfigurieren Einstellen der Funktion und Vernetzung einer 
logischen Einheit, einer (FPGA)-Zelle Oder einer PAE (vgl. 
umkonf igurieren) . 



der PAE. Ausgestaltet durch einen speziell an seine Aufgabe 
angepaliten Mikrokontroller . 



wahrend des H-Pegels transparent weiterleitet und wahrend des 
L-Pegels speichert. In PAEs werden teilweise Latches 
gebraucht, bei denen die Funktion der Pegel genau umgekehrt 
ist. Hierbei wird vor den Takt eines ublichen Latch ein 
Inverter geschaltet. 

Logikzellen Bei DFPs, FPGAs, DPGAs verwendete 

konf igurierbare Zellen, die einfache logische oder 
arithmetische Aufgaben gemafi ihrer Konf iguration erfvillen. 

LookUp-Tabelle(LUT) Tabelle, die einen Wert als Adresse 

erhalt und ein Ergebnis zurucklief ert . Beispielsweise wird 
eine Zahl-als Adresse angegeben und. deren sinus wird 
zuruckgegeben. 

L-Pegel Logisch 0 Pegel, abhangig von der verwendeten 
Technologie 



Ladelogik 



Einheit zum Konfigurieren und Umkonf igurieren 



Latch 



Speicherelement , das ein Signal fur gewohnlich 
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M-PLUREG Register in dem die Vernetzung der PAE gesetzt 

wird. Das Register wird von der PLU beschrieben. 

Maske Eine Bitkombination, die angibt, welche Signale 

einer Quelle weitergeleitet werden und welche Signale 
unterbrochen (ausmaskiert ) werden. 

Mischer Einheit zum Verschalten mehrerer Signale nach einer 
bestimmten Abbildungsvorschrif t . 

a) Fur gewohniich finder eine logische Operation (UND/ODER) 
statt , oqer 

b) die Signale werden zu einem Bus zusammengefalit, wobei evtl. 

c) mehrere Signalquellen uber mehrere Multiplexer selektiv 
zusammengef alit werden. 

Open-Kollektor Schaltungstechnik, bei der der Kollektor eines 
Transistors an einem, liber einen Pullup auf den H-Pegel 
gezogenen, Bussignal liegt. Der Emitter der Transistors liegt 
auf Masse. Schaltet der Transistor, so wird das Bussignal auf 
den L-Pegel gezogen. Vorteil des Verfahrens ist, daft eine 
Mehrzahl solcher Transistoren den Bus ohne elektrische 
Kollision steuern konnen. Dabei sind die Signale ODER- 
verkupft, es entsteht das sog. wired-OR. 

PAE Processing Array Element: EALU mit O-REG, R-REG, 

R20-MUX, F-PLUREG, M-PLUREG, BM-, SM-, Sync-, StateBack- und 
Power-UNIT. 
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Partnerknoten Knoten mit dem ein bestimmter Knoten liber 

ein Bussegment Kontakt hat Oder aufbauen will. 

PLU Einheit zum Konf igurieren und Umkonf igurieren der 

PAE. Ausgestaltet durch einen speziell an seine Aufgabe 
angepaftten Mikrokontroller . 

Prioritatsart Art und Weise, wie eine Prioritatskennung 

ausgewertet wird. 

Prioritatsdekoder Das Signal mit der hochsten Prioritat 

wird weitergegeben oder f reigeschaltet . 

Prioritatskennung Angabe der Prioritat sebene (hoch bis 

nieder) einer Busverbindung . 

Priority-Logik Das Signal mit der hochsten Prioritat wird 

weitergegeben oder f reigeschaltet . 

PullDown Widerstand, der eine Busleitung auf einen L-?egel 
zieht . 

PullUp Widerstand, der eine Busleitung auf einen H-Pegel 
zieht . 
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Quellenoptimiert Ein Bussystem, das meist registered und 
mit niederen Prioritaten aufgebaut ist, um moglichst vielen 
Datensendern (Quellen) den Zugriff auf den Bus zu ermoglichen. 

Raumkoordinaten Angabe von Punkten mittels eines 

mehrdimensionalen Koordinatensystemes . Es konnen absolute 
Koordinaten (exakte Adresse eines Punktes) oder relative 
Koordinaten (relative Entfernung von einem Ausgangspunkt ) 
verwendet werden. Eine Bewegung in positiver Richtung erhoht 
den Zahienwert einer Koordiante, eine Bewegung in negativer 
Richtung verringert den Zahienwert einer Koordinate. 

RECONFIG Von konf igurierbaren Elementen generiertes 

Signal das anzeigt, dafi die Elemente umkonf iguriert werden 
konnen und ihre Aktivitat beendet haben. Wird zum Abriss aller 
beteiligten Busses verwendet und an alle Knoten eines Busses 
gef uhrt . 

Registerbank Zusammenf assung mehrerer in Grofier und 

Funtkion unterschiedlicher Register zu einer Gruppe. 

Register -Bypass Leitung zum Umgehen eines Registers, 

dadurch wlrd der Synchronisationsef f ekt des Registers 
ausgeschaltet . 

RELOAD Neuladen eines Zahlers mit seinem ursprunglich 
gesetzten Wert. 
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Routingtabelle Tabelle innerhalb eines Knotens, die 

Inf ormationen uber auf zubauende Verbindungen enthalt. 

Round-Robin- Arbiter Arbiter , der der Reihe nach ein 

Signal nach dem anderen f reischaltet . Das aktuell 
f reigeschaltete Signal bekommt die niederste Prioritat und 
wird als Letztes in der Kette dann wieder f reigeschaltet . Der 
Arbiter arbeitet im Kreis. 

Sammelschiene Bus auf dem mehrere Bussegmente zusammengef uhrt 
werden . 

Schmitt-Trigger Fensterkomparator, der uber eine Hysterese 

einem Signal genau einen von zwei Werten zuweist und dadurch 
die Signalqualitat verbessert. 

Switching-Tabelle Eine Switching-Tabelle ist ein Ring- 

Speicher, welcher durch eine Steuerung angesprochen wird. Die 
Eintrage einer Switching-Tabelle konnen beliebige 
Konf igurationsworter aufnehmen. Die Steuerung kann Befehle 
durchfuhren. Die Switching-Tabelle reagiert auf Triggersignale 
und konfiguriert konf igurierbare Elemente anhand eines 
Eintrages-in einem Ringspeicher urn. 

Timeout-Generator Einheit zum Generieren eines Timeouts nach 
unterschiedlichen Kriterien, wie 

- Taktzyklen ohne erfolgten Verbindungsauf bau 

- uberrragene Datenpakete 
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- Taktzyklen 

- Taktzyklen ohne Ubertragung 

Timeout Nach Ablauf einer bestimmten Zeit geschieht 

etwas (ein Vorgang wird begonnen oder unterbrochen) . 

Timeout-Zahler siehe Timeout-Generator 

Tor Schalter, der ein Signal weiterleitet oder sperrt. 

Einfacher Vergleich: Relais 

unidirektional Dateniibertragung in eine Richtungen 

(Quelle -> Ziel) 

IMkonfigurieren Neues Konf igurieren von einer 

beliebigen Menge von PAEs wahrend eine beliebige Restmenge von 
PAEs ihre eigenen Funktionen fortsetzen (vgl. konf igurieren) , 

Verbindungsanforderung Die Anforderung eine 

Busverbindung zum Datentransf er aufzubauen. (Auch 
Busanf orderung) 

Zellen - Synonym fur konf igurierbare Elemente 

Zielachse Die X/Y-Achse an der X = 0 ist oder X = Achse, 

bzw. Y = 0 oder Y = Achse ist die Zielachse von X bzw. Y. 



64 



WO 98735294 



PCT/DE98/00456 



Zustandsmaschine Logik, die diversen Zustande annehmen 

kann. Die Ubergange zwischen den Zustanden sind von 
verschiedenen Eingangsparametern abhangig. Diese Maschinen 
werden zur Steuerung komplexer Funktionen eingesetzt und 
entsprechen dem Stand der Technik 
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Namenskonvention 



Baugruppe -UNIT 
Betriebsart -MODE 
Multiplexer -MUX 
Negiertes Signal riot- 
Register fur PLU sichtbar -PLUREG 
Register intern -REG 
Schieberegisters -sf t 



Fun kt ions konvent ion 
NICHT-Funktion ! 



I 


Q 


0 


1 


1 


0 



UND-Funktion & 



A 


B 


Q 


0 


0 


0 


0 


1 


0, 


1 


0 


0 


1 


1 


1 



66 



WO 98/35294 



PCT/DE98/00456 



ODER-Funktion #, > 



A 


B 


Q 


0 


0 


0 


0 


1 


1 


1 


0 


1 


1 


1 


1 



TOR-Funktion G 



EN 


B 


Q 


0 


0 




0 


1 




1 


0 


0 


1 


1 


1 



67 



WO 98735294 



PCT7DE98/00456 



Patentansprliche 

1. Bussystem fur DFPs gemaft DE 44 16 881 Al, sowie Bausteine 
mit zwei- oder mehrdimensionaler programmierbarer Zellst ruktur 
(der Gattungen FPGA, DPGA, o.dgl.), dadurch gekennzeichnet , 
daft 

a) das Bussystem aus einer Vielzahl voneinander 
elektrisch unabhangiger Bussegmente besteht, die liber 
Knoten getrennt sind, 

b) die Knoten Bussegmente aktiv zusammenf ugen oder 
trennen, wobei 

bl) entweder zum Zusammenf ugen mehrere Bussgmente 
liber Tore auf eine, sich innerhalb des Knoten 
bef indende Sammelschiene zusammengeschaltet 
werden, oder 

b2) die Zusammenf ligung direkt liber Schaltelemente, 
Treiber und/oder Register erfolgt, 

c) jeder Knoten eine Routingtabelle besitzt, in der die 

Inf ormationen liber den Aufbau der Verbindungen 
gespeichert sind, 

d) jeder Knoten eine Uberwachungseinheit besitzt, die 

selbstandig prlift ob eine Verbindung aufgebaut werden 
kann oder nicht, 

2. Bussystem nach Patentanspruch 1, dadurch gekennzeichnet , 
daft 

eine Busverbindung schrittweise aufgebaut wird, wobei der 
Datensender zunachst nur die Verbindung zu dem mit ihm 
verbundenen Knoten herstellt, der Knoten dann liber seine 
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Routingtabelle feststellt, welcher ihm benachbarte Knoten fur 
die Verbindung benotigt wird und zu diesem uber das 
verbindende Bussegment Verbindung aufnimmt, sofern dieses 
nicht bereits von einer anderen Verbindung belegt ist; ist 
dies der Fall, so wird der Aufbau der Busverbindung 
abgebrochen oder ausgesetzt; ist dies nicht der Fall, so setzt 
der angesprochene Knoten den Aufbau der Busverbindung fort. 

3. Bussystem nach Patentansspruch 1, dadurch gekennzeichnet , 
daft 

ein Bussegment zur Obertragung eines Datenpaketes aufgebaut 
wird, wobei der Datensender zunachst die Verbindung zu dem mit 
ihm verbundenen Knoten herstellt, der Knoten dann uber seine 
Routingtabelle feststellt, welcher ihm benachbarte Knoten fttr 
die Verbindung benotigt wird und die Daten uber das 
entspechende Bussegment weiterleitet , sofern dieses nicht 
bereits von einer anderen Verbindung belegt ist; ist dies der 
Fall, so wird der Aufbau der Busverbindung ausgesetzt; ist 
dies nicht der Fall, werden die Daten in dem Knoten geloscht 
und von dem benachbarten Knoten weiterverarbeitet . 

4. Bussystem nach Patentanspruch 1-3, dadurch gekennzeichnet, 
dafi 

die Adressen der Daten oder der Verbindung in der Lookup- 
Tabelle eines Knotens auf die Adressen des nachsten Knotens 
ubersetzt werden. 

5. Bussystem nach Patentanspruch 1-3, dadurch gekennzeichnet , 
daft 
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die Adressen der Daten oder der Verbindung in einer 
Berechnungseinheit eines Knotens so verrechnet werden, daft 
entweder die Adresse des nachsten Knotens errechnet wird oder 
liber die Lookup-Tabelle die Adressen des nachsten Knotens 
generiert werden. 

6. Bussystem nach Patentanspruch 1 bis 5, dadurch 
gekennzeichnet, daft 

bei einem f ehlgeschlagenen Verbindungsauf bau der Aufbau zu 
einem spateren Zeitpunkt erneut versucht wird. 

7. Bussystem nach Patentanspruch 1 bis 6, dadurch 
gekennzeichnet, daft 

nach einem erfolgten Verbindungsaufbau die Knoten passiv sind 
und der Datentransf er ausschlieftlich von Datensender und 
Datenempf anger gesteuert werden. 

8. Bussystem nach Patentanspruch 1 bis 6, dadurch 
gekennzeichnet , daft 

ein Knoten aktiv die Daten zu dem nachsten Knoten iibertragt 
und die Synchronisation ubernimmt. 

9. Bussystem nach Patentanspruch 1 bis 8, dadurch 
gekennzeichnet , daft 

weder Datensender noch Datenempf anger , weder wahrend des 
Verbindungsauf baus noch des Betriebs, Kenntniss uber das 
Bussystem haben und keinerlei aktiven Eingriff auf die Knoten 
nehmen . 
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10. Bussystem nach Patentanspruch 1 bis 9, dadurch 
gekennzeichnet , daft 

die Knoten und deren Routingtabellen von einer Ladelogik 
konfiguriert und umkonf iguriert werden. 

11. Bussystem nach Patentanspruch 1 bis 10, dadurch 
gekennzeichnet , dali 

uber die Routingtabellen Ruckmeldungen an die Ladelogik 
gesendet werden konnen. 

12. Bussystem nach Patentanspruch 1 bis 11, dadurch 
gekennzeichnet , dali 

ein Knoten Daten an mehrere andere Knoten gleichzeitig 
versenden kann (Broadcasting) , wobei die 

Synchronisationssignale der empf angenden Knoten einstellbar 
boolsche verknupft und einstellbar maskiert an den sendenden 
Knoten zuruckgegeben werden. 

14. Verfahren zur Obertragung von Daten in DFPs gemaft DE 44 16 
881 Al, sowie Bausteine mit zwei- oder mehrdimensionaler 
prograramierbarer Zellstruktur (der Gattungen FPGA, DPGA, 
o.dgl.), dadurch gekennzeichnet, dali 

die Obertragung der Daten segmentweise auf einem 
mehrdimensionalen Bussystemen erfolgt, wobei die Segmente 
beliebig zusammengeschaltet werden konnen und die 
Datenubertragung synchronisiert erfolgt. 

15. Verfahren nach Anspruch 14 dadurch gekennzeichet , daft 
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die Segmente der Busse fest zu einem durchgangigen 
unverzogerten Bussystem zusammengeschaltet werden. 

16. Verfahren nach Anspruch 14 dadurch gekennzeichet , daft 
die Segmente der Busse durch Register zeitverzogert und 
arbitriert verschaltet werden. 

17. Verfahren nach Anspruch 14 bis 16 dadurch gekennzeichet , 
daft 

die beide Verschaltungsverf ahren gemafi den Abspruchen 15 und 
16 bei einer Verbindung vorkommen. 

18. Verfahren nach Anspruch 14 bis 17 dadurch gekennzeichet , 
daft 

der Aufbau eines Busses durch Lookup-Tabellen gesteuert wird, 
in denen die Verbindungsdaten abgelegt sind, wobei in jeder 
Lookup-Tabelle der Eintrag der nachf olgenden Tabelle 
referenziert ist. 

19* Verfahren nach Anspruch 14 bis 17 dadurch gekennzeichet, 
daft 

der Aufbau des eines Busses durch die Angabe einer eindeutigen 
berechenbaren relativen oder absoluten Adresse des Zieles 
erf olgt . 

20, Verfahren nach Anspruch 14 bis 17 und 19 dadurch 
gekennzeichet, daft 

eine vorliegende Auf baurichtung nur gewechselt wird, wenn die 
Zielachse erreicht ist. 
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21. Verfahren nach Anspruch 14 bis 17 und 19 dadurch 
gekennzeichet , daft 

eine vorliegende Auf baurichtung gewechselt wird, sobald eine 
Blockade in der vorliegenden Auf baurichtung auftritt. 

22. Verfahren nach Anspruch 14 bis 17 und 19 dadurch 
gekennzeichet , daft 

kein Aufbau entgegen der Auf baurichtung und uber die Zielachse 
hinaus erfolgt. 

23. Verfahren nach Anspruch 14 bis 17 und 19 dadurch 
gekennzeichet , daft 

ein Aufbau entgegen der Auf baurichtung und uber die Zielachse 
hinaus erfolgen kann, sofern sich die Abweichung innerhalb 
eines fest vorgegebenen Raumes bewegt . 

24. Verfahren nach Anspruch 14 bis 23 dadurch gekennzeichet, 
dafi 

die beide Auf bauverf ahren gemafi den Abspruchen 18 und 19 bei 
einer Verbindung vorkommen. 

25. Verfahren nach Anspruch 14 bis 24 dadurch gekennzeichet, 
daft 

beim Auftreten mehrere Anf orderungen an einem Knoten die 
Anforderungen arbitriert werden. 

26. Verfahren nach Anspruch 14 bis 25 dadurch gekennzeichet, 
daft 
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beim Auftreten mehrere Anf orderungen eine Mehrzahl von 
Anforderungen zeitgleich behandelt werden. 

27. Verfahren nach Anspruch 14 bis 26 dadurch gekennzeichet , 
dafi 

Daten liber ein Bussegment an einen nachsten Knoten gesendet 
werden und der nachste Knoten die Daten bestatigt. 

28 Verfahren nach Anspruch 14 bis 26 dadurch gekennzeichet , 
dafi 

Daten uber ein Bussegment an mehrere nachsten Knoten gesendet 
werden und die nachste Knoten die Daten bestatigen, wobei die 
Bestatigungssignale beliebig in boolscher Algebra verkmipft 
werden. 

29. Verfahren nach Anspruch 14 bis 26 und 28 dadurch 
gekennzeichet, dali 

Daten uber ein Bussegment an mehrere nachsten Knoten gesendet 
werden und die nachste Knoten die Daten bestatigen, eine Maske 
zum ausmaskieren einzelner Bestatigungssignale existiert. 

30. Verfahren nach Anspruch 14 bis 28 dadurch gekennzeichet, 
dafi 

die beide Ubertragungsverf ahren gemafi den Abspriichen 27 und 28 
bei einer Verbindung vorkommen. 

31. Verfahren nach Anspruch 14 bis 30 dadurch gekennzeichet, 
dafi 
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ein bestehender Bus aufgrund eines Abrifi-Signales aufgelost 
wird, das an alle beteiligten Knoten geleitet wird. 

32. Verfahren nach Anspruch 14 bis 31 dadurch gekennzeichet , 
daft 

ein Abrili-Sigtnal aufgrund einer Zeituberschreitung von einem 
Oder mehreren Knoten generiert wird und an alle beteiligten 
Knoten geleitet wird. 

33. Verfahren nach Anspruch 14 bis 32 dadurch gekennzeichet, 
dafi 

eine Zeituberschreitung aufgrund eines Zeitraums erfolgt, 
indem keine Daten iibertragen wurden. 

34. Verfahren nach Anspruch 14 bis 32 dadurch gekennzeichet, 
dafi 

eine Zeituberschreitung aufgrund eines Zeitraums erfolgt, 
indem Daten iibertragen wurden. 

35. Verfahren nach Anspruch 14 bis 32 dadurch gekennzeichet, 
dafi 

eine Zeituberschreitung aufgrund der ubertragenen Datenmenge 
erfolgt . 

36. Verfahren nach Anspruch 14 bis 32 dadurch gekennzeichet, 
dafi 

eine Zeituberschreitung nicht moglich ist. 
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37. Verfahren nach Anspruch 14 bis 36 dadurch gekennzeichet, 
dafi 

das verwendete Zeituberschreitungsverf ahren fur jedes 
Bussegment gemafc den Anspruchen 33 bis 36 selektiv gewahlt 
wird. 
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Ein Bussystem fur DFPs gemafi DE 44 
16 881 Al, sowie Bausteine mit zwei- oder 
mehrdimensionaler programmierbarer Zellstruktur (der Gattungen FPGA, DPGA, o.dgl.) ist dadurch gekennzeichnet, daB a) das Bussystem 
aus einer Vielzahl voneinander elektrisch unabh§ngiger Bussegmente besteht, die Qber Knoten getrennt sind, b) die Knoten Bussegmente 
akriv zusammennlgen oder trennen, wobei bl) entweder zum Zusammenfugen mehrere Bussegmente Qber Tore auf eine, sich innerhalb 
des Knoten befindende Sammelschienen zusammengeschaltet werden, oder b2) die ZusammenfQgung direkt Qber Schaltelemente, Treiber 
und/oder Register erfolgt, c) jeder Knoten eine Routingtabelle besitzt, in der die Informationen ilber den Aufbau der Verbindungen gespeichert 
sind, d) jeder Knoten cine Oberwachungscinheit besitzt, die selbstandig prOft, ob eine Verbindung aufgebaut werden kann oder nicht 
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